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

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. Python 函数 参数传递

    参数传递    在 python 中,类型属于对象,变量是没有类型的:        a=[1,2,3]        a="Runoob"    以上代码中,[1,2,3] 是 ...

  2. [cf1261F]Xor-Set

    构造一棵权值范围恰为$[0,2^{60})$的权值线段树,考虑其中从下往上第$h$层($0\le h\le 60$)中的一个区间,假设其左端点为$l$,即$[l,l+2^{h})$ 这样的一个区间具有 ...

  3. [loj3315]抽卡

    令$S$表示对于某一种抽卡顺序中某一段长度为$k$的段全部被抽到的时间(这里没有期望)所构成的集合,根据$min-max$容斥的公式,有$E(\min(S))=\sum_{T\subseteq S}( ...

  4. 数字逻辑实践3->EDA技术与Verilog设计

    本文属于EDA技术概述类文章 1 EDA技术及其发展 概念 EDA(Electronic Design Automation),指的是以计算机为工作平台,以EDA软件工具为开发环境,以PLD期间或者A ...

  5. Java 单例模式大乱斗

    1. 饿汉模式 线程安全 public class SingleInstance1 { private static SingleInstance1 single=new SingleInstance ...

  6. vscode 整理————开篇之力(一)

    前言 作为一个开发为什么对一个vscode 这样的工具进行整理呢,因为vscode 非常的常用,它包含很多编辑器共同有的特征,这些特征帮助我们了解其他编辑器. 这里可能就有人疑问了,我们需要去非常的关 ...

  7. 基于Ubuntu 18.04.5 LTS 部署Ceph集群测试及Ceph RDB的使用。

    1.ceph简介 Ceph在一个统一的系统中独特地提供对象.块和文件存储 1.1 ceph官网架构图 1.2 架构解释   CEPH 对象存储 CEPH 块设备 CEPH 文件系统 RESTful 接 ...

  8. WebGoat8.2.2-A8不安全的反序列化

    1.概念   使用反序列化在各编程语言中略有不同,如Java.PHP.Python.Ruby.C/C++,但在关键概念上是一样的     序列化:将(内存中的)对象转化成数据格式,以便存储或传输   ...

  9. Atcoder Grand Contest 001 D - Arrays and Palindrome(构造)

    Atcoder 题面传送门 洛谷题面传送门 又是道思维题,又是道把我搞自闭的题. 首先考虑对于固定的 \(a_1,a_2,\dots,a_n;b_1,b_2,\dots,b_m\) 怎样判定是否合法, ...

  10. 洛谷 P5853 - [USACO19DEC]Tree Depth P(生成函数+背包)

    洛谷题面传送门 神仙题. 首先考虑一个点的深度是什么,注意到对于笛卡尔树而言直接从序列的角度计算一个点的深度是不容易的,因为这样会牵扯到序列中多个元素,需要 fixed 的东西太多,计算起来太复杂了. ...