为了账号安全,请及时绑定邮箱和手机立即绑定

请问一下在racle里synonym的作用是什么?

/ 猿问

请问一下在racle里synonym的作用是什么?

慕盖茨9453107 2019-11-12 14:11:18

racle里synonym的作用是什么?


查看完整描述

4 回答

?
慕工程0101907

Oracle同义词的作用是:

1、 多用户协同开发中,可以屏蔽对象的名字及其持有者。如果没有同义词,当操作其他用户的表时,必须通过user名.object名的形式,采用了Oracle同义词之后就可以隐蔽掉user名。

当然这里要注意的是:public同义词只是为数据库对象定义了一个公共的别名,其他用户能否通过这个别名访问这个数据库对象,还要看是否已经为这个用户授权。

2、为用户简化sql语句。上面的一条其实就是一种简化sql的体现,同时如果自己建的表的名字很长,可以为这个表创建一个Oracle同义词来简化sql开发。

3、为分布式数据库的远程对象提供位置透明性。

扩展资料:

Oracle数据库中提供了同义词管理的功能。同义词是数据库方案对象的一个别名,经常用于简化对象访问和提高对象访问的安全性。在使用同义词时,Oracle数据库将它翻译成对应方案对象的名字。与视图类似,同义词并不占用实际存储空间,只有在数据字典中保存了同义词的定义。

在Oracle数据库中的大部分数据库对象,如表、视图、同义词、序列、存储过程、包等等,数据库管理员都可以根据实际情况为他们定义同义词。Oracle同义词有两种类型,分别是公用Oracle同义词与私有Oracle同义词。



查看完整回答
反对 回复 2019-11-19
?
呼唤远方

CREATE [PUBLIC]SYNONYM synonym For schema.object

隐藏对象的名称和所有者:
select count(*) from hr.employees;
create synonym emp for hr.employees; --默认属于donny用户,是donny的私有对象private
select count(*) from emp;

分布式数据库的远程对象提供了位置透明性:
访问其他数据库时,要首先建立数据库连结:
CREATE DATABASE LINK test_link CONNECT TO username IDENTIFIED BY pass USING 'orabase';
Select count(*) from hr.employees@test_link;
create synonym link_emp for hr.employees@test_link;
select count(*) from link_emp;

提供对象的公共访问:
create public synonym pub_emp for hr.employees;
pub_emp属于public用户,数据库所有用户都可以访问。

同义词类型
–私有 emp 实际上donny.emp
–公用 pub_emp 所有用户都可以直接访问

当公有对象和私有对象同名时(因为数据不同的用户,所以可以),以私有对象优先。(类似于局部变量)
desc dba_synonyms/ user_synonyms/ all_synonyms 数据字典,复数
tab公有同义词
建立私有的tab表,查看效果。

删除同义词:
drop synonym donny.emp;
drop public synonym pub_emp;



查看完整回答
反对 回复 2019-11-19
?
慕盖茨1488219

是表的同义词, 作用跟 查询里面的 为字段定义的别名差不多。
比如a用户的表aa,你是b,本来查询他的表应该写select * from a.aa 如果给a.aa定义个同义词bb ,就可用写select * from b 。
好处呢 一,手写查询时比较简便点;二,如果写程序调用的话,如果数据表啊什么的有变化了,程序不用改写,只需要重新定义个同义词就行了

查看完整回答
反对 回复 2019-11-19
?
叮当猫咪

有的。PostgreSQL内建有分析函数,PostgreSQL称之为Window Function,有如下这些:
row_number()
rank()
dense_rank()
percent_rank()
cume_dist()
ntile(num_buckets integer)
lag(value any [, offset integer [, default any ]])
lead(value any [, offset integer [, default any ]])
first_value(value any)
last_value(value any)
nth_value(value any, nth integer)
具体说明参看PostgreSQL说明文件中Funcstions & Operates下的Winow Functions。



查看完整回答
反对 回复 2019-11-19

添加回答

回复

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信