Oracle一个用户查询另一个用户的表数据

1、两个用户是在不同的库,需要建立dblink

 

2、属于同一个库的不同用户

1)方法一:使用"用户名."的方式访问

  例如:要从USER1账号访问USER2中的表TABLE2

  A. 需要在USER2中将TABLE2 GRANT给USER1,USER1才有权限访问,访问的时候用SELECT * FROM USER2.TABLE2语句

  B.也可以直接给用户USER1赋予dba权限,待使用完后再取出dba,不过很危险就是了。

 

2)方法二:和查询当前用户的方法一样,查询另一个用户的表信息

如果不想在TABLE2前面加上SCHEMA(USER2),需要在USER1中建立TABLE2的同义词(SYNONYM),或者在USER2中建立TABLE2的PUBLIC SYNONYM(这个好处是如果你有第三个账号也想访问这张表,那么也是有同义词的,不要额外再建)

posted @ 2016-05-16 15:58  NewLife365  阅读(11670)  评论(0编辑  收藏  举报