Oracle 同义词和视图

本文探讨了在数据库管理中如何使用SQL语句授予特定用户权限,通过创建视图来限制用户仅能查看特定数据,并介绍了同义词和公共同义词的使用方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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;

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值