A_oe用户访问A_hr下的员工表

/*
===========================================================
|          将访问员工表的权限授予A_oe用户
============================================================
*/   
GRANT SELECT ON employee TO A_oe;


--以A_oe用户登录   
SELECT * FROM A_hr.employee;

--是否有更好的解决方案?

 

视图

/*
===========================================================
|         在订单表中,只允许当前员工查看自己的订单记录
============================================================
*/
--当前用户A_oe
--获得create view权限

CREATE OR REPLACE VIEW v_myOrders
AS
SELECT * 
  FROM orders 
 WHERE sales_rep_id=(SELECT empno
                       FROM employee 
                      WHERE ename=(SELECT USER FROM dual));

SELECT * FROM v_myOrders;

/*
===========================================================
|         在员工表中,普通职员只允许看姓名、部门列
============================================================
*/
--当前用户A_hr
CREATE OR REPLACE VIEW v_employee
AS
SELECT empno,ename,e.deptno,dname 
  FROM employee e INNER JOIN dept d 
    ON e.deptno=d.deptno;

 

同义词

/*
===========================================================
|          创建私有同义词
============================================================
*/
CREATE OR REPLACE SYNONYM emp FOR employee;

/*
===========================================================
|          创建公有同义词
============================================================
*/     
CREATE PUBLIC SYNONYM employee FOR A_hr.employee;

GRANT SELECT ON employee TO A_oe;   

----以A_oe用户登录   
--SELECT * FROM A_hr.employee;
SELECT * FROM employee;
/*
===========================================================
|          删除同义词
============================================================
*/   
DROP SYNONYM emp; 
DROP PUBLIC SYNONYM employee; 

/*
===========================================================
|          其他用户都可以访问A_hr用户下的employee表
============================================================
*/   
GRANT SELECT ON A_hr.employee TO public;
CREATE PUBLIC SYNONYM employee FOR A_hr.employee;

--以其他用户登录
SELECT * FROM employee;