同义词 是什么个概念。主要用在什么地方

解决方案 »

  1.   

    同义词 其实类似于起别名 
    比如 create synonym std for scott.student;就是给scott用户的student表起了个别名 下次在你创建同义词的 用户下调用 直接用std就行 比如 select* from std;
      

  2.   

    同义词 其实类似于起别名 
    比如 create synonym std for scott.student;(synonym是同义词的意思)就相当于给scott用户的student表起了个别名 下次在你创建同义词的 用户下调用 直接用std就行 比如 select* from std; 但是,这个同义词仅仅在你创建该同义词的用户下有效,也就是说是私有的。
    如果要创建对所有用户都有效的同义词,应该先以dba身份登陆,接着
    create public synonym std for scott.student; 这样所有用户都可以适用std同义词了!
      

  3.   

    从字面上理解就是别名的意思,和试图的功能类似。就是一种映射关系。  1.创建同义词语句:  create public synonym table_name for user.table_name; 
      其中第一个user_table和第二个user_table可以不一样。  此外如果要创建一个远程的数据库上的某张表的同义词,需要先创建一个Database Link(数据库连接)来扩展访问,然后在使用如下语句创建数据库同义词:create synonym table_name for table_name@DB_Link;  当然,你可能需要在user用户中给当前用户(user2)授权: grant select/delete/update on user2  2.删除同义词:  drop public synonym table_name; 
      3.查看所有同义词:  select * from dba_synonyms 
      同义词拥有如下好处:节省大量的数据库空间,对不同用户的操作同一张表没有多少差别;扩展的数据库的使用范围,能够在不同的数据库用户之间实现无缝交互;同义词可以创建在不同一个数据库服务器上,通过网络实现连接。