Oracle 存储过程中的权限问题
时间:2011-11-14
来源:互联网
3.1有趣的现象:
1:首先用userdb1用户登录数据库,然后创建一个新表xujs_user
create table xujs_user(id number,name varchar2(21));
2:在数据字典ALL_OBJECTS中(sysdb1用户下)查询刚刚新建的两个表的相关信息。
select * from all_objects where object_name=upper('xujs_user') and object_type=upper('table');
查出的记录条数为1.
4:sysdb1用户下创建存储过程如下:
create or replace procedure xujs is
v_count number:=0;
begin
select count(1) into v_count from all_objects where object_name='XUJS_USER' and object_type='TABLE';
end;
/
5:在sysdb1用户下执行这个存储过程,在存储过程中就查询不到XUJS_USER的信息。即:
select count(1) into v_count from all_objects where object_name='XUJS_USER' and object_type='TABLE';
中的v_count为0
6:修改存储过程,加上authid current_user,再执行存储过程,就可以查询到XUJS_USER的信息了,即:
select count(1) into v_count from all_objects where object_name='XUJS_USER' and object_type='TABLE';
中的v_count为1
问题:1:为什么单独执行select * from all_objects 的时候可以在字典中查到我刚建的表的相关信息,而在过程中就查不到
2:为什么加了authid current_user as 就可以在字典中查询到表的信息呢?
1:首先用userdb1用户登录数据库,然后创建一个新表xujs_user
create table xujs_user(id number,name varchar2(21));
2:在数据字典ALL_OBJECTS中(sysdb1用户下)查询刚刚新建的两个表的相关信息。
select * from all_objects where object_name=upper('xujs_user') and object_type=upper('table');
查出的记录条数为1.
4:sysdb1用户下创建存储过程如下:
create or replace procedure xujs is
v_count number:=0;
begin
select count(1) into v_count from all_objects where object_name='XUJS_USER' and object_type='TABLE';
end;
/
5:在sysdb1用户下执行这个存储过程,在存储过程中就查询不到XUJS_USER的信息。即:
select count(1) into v_count from all_objects where object_name='XUJS_USER' and object_type='TABLE';
中的v_count为0
6:修改存储过程,加上authid current_user,再执行存储过程,就可以查询到XUJS_USER的信息了,即:
select count(1) into v_count from all_objects where object_name='XUJS_USER' and object_type='TABLE';
中的v_count为1
问题:1:为什么单独执行select * from all_objects 的时候可以在字典中查到我刚建的表的相关信息,而在过程中就查不到
2:为什么加了authid current_user as 就可以在字典中查询到表的信息呢?
作者: howloncampus 发布时间: 2011-11-14
HTML code
http://space.itpub.net/23445793/viewspace-630952
作者: cosio 发布时间: 2011-11-14
咦?不太清楚。
我和你的操作过程是一样的,但是我没加authid current_user就可以在sysdb1执行存储过程,并得到1的返回值。
我和你的操作过程是一样的,但是我没加authid current_user就可以在sysdb1执行存储过程,并得到1的返回值。
作者: yixilan 发布时间: 2011-11-14
没看懂,哈哈
作者: zywcy100 发布时间: 2011-11-14
相关阅读 更多
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28