Oracle 同义词和视图

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;

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值