学习Oracle遇到的实际问题(持续更新)
有三个用户参与这个事情:
system用户,拥有表manager。
sys create了一个用户item,并赋予权限:
SQL> GRANT SELECT ON SYSTEM.MANAGER TO ITEM;
SQL> GRANT INSERT ON SYSTEM.MANAGER TO ITEM;
这时 sys用户进行的操作:
SQL> set transaction name 'INSERT INTO TABLE manager';
事务处理集。
SQL> insert into system.manager
2 values (15,'AA','seter','2200');
已创建 1 行。
已用时间: 00: 00: 00.00
SQL> select name from v$transaction;
NAME
----------------------------------------------------------------------------------------------------
INSERT INTO TABLE manager
已选择2行。
已用时间: 00: 00: 00.01
此时在 item 用户窗口可以查看到数据的更新:
SQL> select * from system.manager;
MGRNO MNAME JOB REMARK
---------- ------------------------------ ------------------------------ -------------
12 Smith manager 3600
13 Paul coder 3000
15 AA seter 2200
14 Daisy tester 2000
已选择4行。
但是 在item 用户窗口进行操作:
SQL> insert into system.manager
2 values ( 16,'BB','bb','2000')
3 /
已创建 1 行。
SQL> select * from system.manager;
MGRNO MNAME JOB REMARK
---------- ------------------------------ ------------------------------ --------------
12 Smith manager 3600
13 Paul coder 3000
15 AA seter 2200
14 Daisy tester 2000
16 BB bb 2000
已选择5行。
而在sys窗口进行查询的时候却看不到item用户对manager表的操作结果。这是为什么呢? 为什么呢 ?
SQL> select * from system.manager;
MGRNO MNAME JOB
---------- ------------------------------ ------------------------
REMARK
------------------------------------------------------------------
12 Smith manager
3600
13 Paul coder
3000
15 AA seter
2200
我再用system用户连接数据库查看表manager发现数据确实改变了的:
C:\Users\dingqi>sqlplus system@dabook
SQL*Plus: Release 11.2.0.1.0 Production on 星期日 9月 15 00:05:56
Copyright (c) 1982, 2010, Oracle. All rights reserved.
输入口令:
连接到:
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - Produ
With the Partitioning, OLAP, Data Mining and Real Application Tes
SQL> SET PAGESIZE 25
SQL> SET TIMING ON
SQL> SET FEEDBACK ON
SQL> select * from manager;
MGRNO MNAME JOB
---------- ------------------------------ -----------------------
REMARK
-----------------------------------------------------------------
12 Smith manager
3600
13 Paul coder
3000
15 AA seter
2200
14 Daisy tester
2000
16 BB bb
2000
已选择5行。
原因: 在item窗口进行DML 语句的操作 需要显式提交 COMMIT;因为ORACLE会隐式的提交DDL语句。
DDL语句包括:
create alter drop 模式对象及其他数据库结构(包括数据库本身及数据库用户)
rename数据库对象
删除所有的数据 (truncate)
管理权限(grant revoke)
设置审计(audit noaudit)
添加注释(COMMENT)到数据字典
DML语句包括:
从表或视图中检索数据(select)
往表或视图中插入数据(insert)
修改列的值(update)
有条件的往表或试图中插入或更新数据(merge)
从表或视图中删除数据(delete)
查看SQL语句的执行计划(explain plan)
锁住表及用户
哈哈 小误会。不过亲身体会的感觉还是很爽的。。
问题2: system 创建procedure,execute的时候却提示权限不足,真是气死我了!
SQL> CREATE OR REPLACE PROCEDURE p_create_view
2 is
3 sql_string varchar2(500);
4 BEGIN
5 sql_string :='CREATE view v_zero3 as SELECT * FROM s
6 EXECUTE IMMEDIATE sql_string;
7 END;
8 /
过程已创建。
已用时间: 00: 00: 00.27
SQL> execute p_create_view;
BEGIN p_create_view; END;
*
第 1 行出现错误:
ORA-01031: 权限不足
ORA-06512: 在 "SYSTEM.P_CREATE_VIEW", line 6
ORA-06512: 在 line 1
解决办法:在create procedure的时候加上一句authid current_user 解决。
CREATE OR REPLACE PROCEDURE p_create_view
authid current_user is
sql_string varchar2(500);
BEGIN
sql_string :='CREATE view v_zero3 as SELECT * FROM system.manager';
EXECUTE IMMEDIATE sql_string;
END;
Authid Current_User:以执行过程的用户的权限来处理涉及的对象权限.
学习Oracle遇到的实际问题(持续更新)的更多相关文章
- C++入职学习篇--代码规范(持续更新)
C++入职学习篇--代码规范(持续更新) 一.头文件规范 在头文件中大家一般会定义宏.引入库函数.声明.定义全局变量等,在设计时最后进行分类,代码示范(自己瞎琢磨的,请多多指点): #ifndef T ...
- java 学习必备的软件,持续更新中
小编会持续更新在学习Java过程中需要的软件以及各种文件: 话不多说,看行动! 一:JDK (1)JDK1.8(*64): 链接:https://pan.baidu.com/s/1vM0jNXn2CT ...
- 资源| 学习视频库-永久有效,持续更新!附赠java面试汇总
每天进步一丢丢,连接梦与想 我们总是羡慕他人的光芒,却忘记自己也会发光 声明 资源来自于网络,小编只是资源的搬运工,若有侵权,联系小编即删. 期待已久的学习视频库来啦! 经过小编多日整理,整理了1.5 ...
- oracle 常用操作记录--持续更新...
一.oracle grant 授权语句(转自:https://www.cnblogs.com/yt954437595/p/6488819.html) --select * from dba_users ...
- Oracle常用命令(持续更新)
--1.解锁用户 alter user 用户名 account unlock; --2.开启最小补充日志记录(执行的DML操作会被记录下来) alter database add supplemen ...
- Oracle自用脚本(持续更新)
--查询Oracle正在执行的sql语句及执行该语句的用户 SELECT b.sid oracleID, b.username 登录Oracle用户名, b.serial#, spid 操作系统ID, ...
- 【Android XMPP】 学习资料收集贴(持续更新)
系列一: 基于xmpp openfire smack开发之openfire介绍和部署[1] 基于xmpp openfire smack开发之smack类库介绍和使用[2] 基于xmpp openfir ...
- 【Python灰帽子--黑客与逆向工程师的Python编程之道】我的学习笔记,过程.(持续更新HOT)
我的学习笔记---python灰帽子 世界让我遍体鳞伤,但伤口长出的却是翅膀. -------------------------------------------- 前言 本书是由知名安全机构Im ...
- JVM学习--内存分配策略(持续更新)
一.前言 最近学习<深入java虚拟机>,目前看到内存分配策略这块.本文将进行一些实践. 二.内存分配策略 1.大对象直接进入老年代 书中提到了: 下面进行测试,代码如下: public ...
随机推荐
- golang常用库:日志记录库-logrus使用
介绍 logrus 它是一个结构化.插件化的日志记录库.完全兼容 golang 标准库中的日志模块.它还内置了 2 种日志输出格式 JSONFormatter 和 TextFormatter,来定义输 ...
- 大一C语言学习笔记(5)---函数篇-定义函数需要了解注意的地方;定义函数的易错点;详细说明函数的每个组合部分的功能及注意事项
博主学习C语言是通过B站上的<郝斌C语言自学教程>,对于C语言初学者来说,我认为郝斌真的是在全网C语言学习课程中讲的最全面,到位的一个,这个不是真不是博主我吹他哈,大家可以去B站去看看,C ...
- 大一C语言学习笔记(1)---编译顺序问题;不同数据类型赋值,运算问题;算数运算符易错点(以解一元二次方程为例)
废话少说,上代码: #include<stdio.h> #include<math.h> int main()//解一元二次方程 { int a,b,c; double too ...
- 3组-Alpha冲刺-2/6
一.基本情况 队名:发际线和我作队 组长博客:链接 小组人数:10 二.冲刺概况汇报 黄新成(组长) 过去两天完成了哪些任务 文字描述 在校内外进行了数据采集,采集了多场景的数据,并进行了帧分割. 展 ...
- c++学习笔记5(函数的缺省参数)
例: void func(int x1,int x2=2,int x3=3){} func (10)//等效于func (10,2,3) func (10,8)//等效于func (10,8,3) f ...
- 尖端之作看逐浪-Zoomla!逐浪CMS python版发布
免费下载:https://www.z01.com/down/3723.shtml Python是跻身于当代IT世界最流行和代码最高效的编程语言之一. 带着对技术的卓越追求.对客户的承诺.对品质的极致追 ...
- java开发环境搭建,配置
java开发环境搭建 下载jdk8的地址 是oracle的 安装JDK 下载电脑对应的版本 双击安装JDK 记住安装路径 配置环境变量 我的电脑/此电脑 右键属性 高级设置 环境变量 点击新建 变量名 ...
- shell脚本训练
*注:shell中的/data目录为自创练习目录 1,编写脚本systeminfo.sh,显示当前主机系统信息.包括主机名,IPV4地址,操作系统版本,内核版本,cpu型号,内存大小,硬盘大小 结果: ...
- Java设计模式之(九)——门面模式
1.什么是门面模式? Provide a unified interface to a set of interfaces in a subsystem.Facade defines a higher ...
- 洛谷 P3700 - [CQOI2017]小Q的表格(找性质+数论)
洛谷题面传送门 又是一道需要一些观察的数论 hot tea-- 注意到题目中 \(b·f(a,a+b)=(a+b)·f(a,b)\) 这个柿子长得有点像求解 \(\gcd\) 的辗转相除法,因此考虑从 ...