आप इसे सामान्य दृश्य के साथ कर सकते हैं, जब तक कि इसमें शामिल उपयोगकर्ता पहले से ही बेस टेबल तक पहुंच नहीं पाए हैं।
ईजी:
SQL> create user reportuser identified by reportuser;
User created.
SQL> grant create session to reportuser;
Grant succeeded.
SQL> grant create synonym to reportuser;
Grant succeeded.
SQL> select user from dual;
USER
------------------------------
PHIL
SQL> create table basetable
(
id number primary key,
viewable varchar2(30),
secret varchar2(30)
);
Table created.
SQL> insert into basetable values ( 1, 'hello world','this is secret' );
1 row created.
SQL> commit;
Commit complete.
SQL> create view reportview
as
select id, viewable
from basetable;
View created.
SQL> grant select on reportview to reportuser;
Grant succeeded.
SQL> conn reportuser/reportuser
Connected.
SQL> select * from phil.basetable;
select * from phil.basetable
*
ERROR at line 1:
ORA-00942: table or view does not exist
SQL> select secret from phil.basetable;
select secret from phil.basetable
*
ERROR at line 1:
ORA-00942: table or view does not exist
SQL> select * from phil.reportview;
ID VIEWABLE
---------- ------------------------------
1 hello world
SQL>
यदि आप प्रश्न में तालिकाओं पर अनुमतियों को रद्द करते हैं और विचार बनाते हैं, साथ ही प्रत्येक उपयोगकर्ता के लिए एक समानार्थी शब्द के साथ मूल तालिका के समान नाम है, तो यह पारदर्शी होना चाहिए।
ईजी:
SQL> select user from dual;
USER
------------------------------
REPORTUSER
SQL> create synonym basetable for phil.reportview;
Synonym created.
SQL> select * from basetable;
ID VIEWABLE
---------- ------------------------------
1 hello world
SQL>
आप वर्चुअल प्राइवेट डेटाबेस के साथ भी ऐसा कर सकते हैं , लेकिन मुझे लगता है कि यह एक महंगा अतिरिक्त लाइसेंस वाला विकल्प है। आप संबंधित सुरक्षा नीतियों को कॉन्फ़िगर करने के लिए DBMS_RLS का उपयोग करते हैं जिनकी आपको आवश्यकता होती है।