create synonym table_name for user table_name
其中第一个user_table和第二个user_table可以不一样
此外如果要创建一个远程的数据库上的某张表的同义词 需要先创建一个Database Link(数据库连接)来扩展访问 然后在使用如下语句创建数据库同义词 create synonym table_name for table_name@DB_Link
当然 你可能需要在user用户中给当前用户(user )授权 grant select/delete/update on user
创建好同义词之后 你可以对它进行DML(insert update delete) *** 作 当然select语句时肯定支持的 删除同义词 drop synonym table_name这里的table_name是指同义词的表名
同义词拥有如下好处 节省大量的数据库空间 对不同用户的 *** 作同一张表没有多少差别 扩展的数据库的使用范围 能够在不同的数据库用户之间实现无缝交互 同义词可以创建在不同一个数据库服务器上 通过网络实现连接
查看所有同义词
select * from dba_synonyms
在oracle中创建同义词我们都知道 在oracle中对用户的管理是使用权限的方式来管理的 也就是说 如果我们想使用数据库 我们就必须得有权限 但是如果是别人将权限授予了我们 我们也是能对数据库进行 *** 作的 但是我们必须要已授权的表的名称前键入该表所有者的名称 所以这就是比较麻烦的 遇到这种情况 我们该怎么办呢?创建个同义词吧!这样我们就可以直接使用同义词来使用表了
创建同义词的具体语法是 create [public] SYNONYM synooym for object其中synooym表示要创建的同义词的名称 object表示表 视图 序列等我们要创建同义词的对象的名称
CREATE PUBLIC SYNONYM public_emp FOR jward empjward 用户名
删除同义词
使用DROP SYNONYM语句删除不再需要的同义词 要想删除私有同义词 就省略 PUBLIC 关键字要想删除公共同义词就要包括PUBLIC 关键字
DROP SYNONYM emp删除名为emp 的私有同义词
lishixinzhi/Article/program/Oracle/201311/18310
我们需要准备的材料分别是:电脑、oracle。
1、首先打开oracle,如果想要实现表空间的方法,则输入以下代码:
2、如果想要实现用户的方法,则输入以下代码:
3、如果想要实现表的方法,则输入以下代码:
4、如果想要实现索引的方法,则输入以下代码:
5、如果想要实现序列号的方法,则输入以下代码:
6、如果想要实现视图的方法,则输入以下代码:
可以通过创建同义词的方法来解决.同义词,相当于alias(别名),处理方式如下:
例如:现有user1用户、user2用户;其中user1用户有表tb_1,现在user2用户通过“同义词”tb_2来达到 *** 作user1用户的表tb_1:
create
or
replace
synonym
tb_2
for
user1.tb_1
这样当你在user2中查select
*
from
tb_2时就相当于查select
*
from
user1.tb_1了。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)