有三个用户参与这个事情:

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遇到的实际问题(持续更新)的更多相关文章

  1. C++入职学习篇--代码规范(持续更新)

    C++入职学习篇--代码规范(持续更新) 一.头文件规范 在头文件中大家一般会定义宏.引入库函数.声明.定义全局变量等,在设计时最后进行分类,代码示范(自己瞎琢磨的,请多多指点): #ifndef T ...

  2. java 学习必备的软件,持续更新中

    小编会持续更新在学习Java过程中需要的软件以及各种文件: 话不多说,看行动! 一:JDK (1)JDK1.8(*64): 链接:https://pan.baidu.com/s/1vM0jNXn2CT ...

  3. 资源| 学习视频库-永久有效,持续更新!附赠java面试汇总

    每天进步一丢丢,连接梦与想 我们总是羡慕他人的光芒,却忘记自己也会发光 声明 资源来自于网络,小编只是资源的搬运工,若有侵权,联系小编即删. 期待已久的学习视频库来啦! 经过小编多日整理,整理了1.5 ...

  4. oracle 常用操作记录--持续更新...

    一.oracle grant 授权语句(转自:https://www.cnblogs.com/yt954437595/p/6488819.html) --select * from dba_users ...

  5. Oracle常用命令(持续更新)

    --1.解锁用户 alter user 用户名 account unlock; --2.开启最小补充日志记录(执行的DML操作会被记录下来)  alter database add supplemen ...

  6. Oracle自用脚本(持续更新)

    --查询Oracle正在执行的sql语句及执行该语句的用户 SELECT b.sid oracleID, b.username 登录Oracle用户名, b.serial#, spid 操作系统ID, ...

  7. 【Android XMPP】 学习资料收集贴(持续更新)

    系列一: 基于xmpp openfire smack开发之openfire介绍和部署[1] 基于xmpp openfire smack开发之smack类库介绍和使用[2] 基于xmpp openfir ...

  8. 【Python灰帽子--黑客与逆向工程师的Python编程之道】我的学习笔记,过程.(持续更新HOT)

    我的学习笔记---python灰帽子 世界让我遍体鳞伤,但伤口长出的却是翅膀. -------------------------------------------- 前言 本书是由知名安全机构Im ...

  9. JVM学习--内存分配策略(持续更新)

    一.前言 最近学习<深入java虚拟机>,目前看到内存分配策略这块.本文将进行一些实践. 二.内存分配策略 1.大对象直接进入老年代 书中提到了: 下面进行测试,代码如下: public ...

随机推荐

  1. go 错误处理设计思考

    前段时间准备对线上一个golang系统服务进行内部开源,对代码里面的错误处理进行了一波优化. 优化的几个原因: 错误处理信息随意,未分类未定义.看到错误日志不能第一时间定位 错误的日志重复,有时候一个 ...

  2. PHP高级特性-反射Reflection以及Factory工厂设计模式的结合使用[代码实例]

    PHP高级特性-反射以及工厂设计模式的结合使用 [结合 Laravel-Admin 代码实例讲解] 利用反射来实现工厂模式的生产而无需创建特定的工厂类 本文地址http://janrs.com/?p= ...

  3. ubuntu更換清華軟件源

    打开软件源的编辑sudo gedit /etc/apt/sources.list 软件源: Ubuntu--更改国内镜像源(阿里.网易.清华.中科大) 打開軟件源文件進行修改: 使用 sudo vim ...

  4. 100_第一个vue-cli项目

    目录 什么是vue-cli 主要的功能 需要的环境 Node.js : http://nodejs.cn/download/ Git : https://git-scm.com/downloads 安 ...

  5. 利用Fastjson注入Spring内存马

    此篇文章在于记录自己对spring内存马的实验研究 一.环境搭建 搭建漏洞环境,利用fastjson反序列化,通过JNDI下载恶意的class文件,触发恶意类的构造函数中代码,注入controller ...

  6. 关于【【故障公告】数据库服务器 CPU 近 100% 引发的故障(源于 .NET Core 3.0 的一个 bug)】IS NOT NULL测试

    测试如图,Core_Users的PhoneNumber可为空,存在索引,记录数1500000+ 增加is not null,查询计划消耗增加了一个0%的筛选器消耗,IO消耗如下一模一样 如果是IS N ...

  7. [loj2265]最长上升子序列

    以下内容参考2019年集训队论文<浅谈杨氏矩阵在信息学竞赛中的应用> 1.前置知识 杨表 标准杨表:一张网格图,满足以下条件-- 1.设其有$m$行.第$i$行有$a_{i}$个格子(格子 ...

  8. [loj3272]汉堡肉

    当$k\le 3$,这是一个经典的问题 设所有矩形左下角横纵坐标的最大值为$(x_{1},y_{1})$,右上角横纵坐标的最小值为$(x_{2},y_{2})$,那么必然存在一组合法解满足其中一点为$ ...

  9. Java安全之Axis漏洞分析

    Java安全之Axis漏洞分析 0x00 前言 看到个别代码常出现里面有一些Axis组件,没去仔细研究过该漏洞.研究记录一下. 0x01 漏洞复现 漏洞版本:axis=<1.4 Axis1.4 ...

  10. es的rest风格的api文档

    rest风格的api put http://127.0.0.1:9200/索引名称/类型名称/文档id (创建文档,指定文档id) post http://127.0.0.1:9200/索引名称/类型 ...