zoukankan      html  css  js  c++  java
  • Oracle用户的单张表的读写权限控制

    在oracle数据库的用户下,一张表需要做读写控制,只能读和写,不能删除和修改。开发人员开始想从用户权限上去实现。
    经过一番讨论,判读从权限上去实现该需求是不合适的。
    这个用户下很多表,根本不会被一个人控制的。用户本身有一个权限组resource,可以对其下所有表进行增删改查。
    如果要用权限来实现,那么就得将这个组去掉。这样,该用户下的其他表就得一个一个授权。还得考虑到以后新建的表。如何处理又是个问题。

    因此,判断该解决方式不合适。

    这种单独一张表的读写控制,不知道审计能不能实现。我想到一种另外的控制方法,让表只能读写,不能删改。这个方法就是利用触发器。
    在表的每一行纪录进行增删改之前做判断,如果是增,则不做任何处理,如果是删除或者修改,直接rollback。
    这样就实现了这种读写控制。

    触发器代码如下:

    create or replace trigger trg_test_insert_select
      before insert or  update or  delete on t_test  
      for each row
    declare
      -- local variables here
    begin
        CASE
        WHEN INSERTING THEN
          DBMS_OUTPUT.PUT_LINE('Inserting');
        WHEN UPDATING THEN
          DBMS_OUTPUT.PUT_LINE('Updating');
          rollback;
        WHEN DELETING THEN
          DBMS_OUTPUT.PUT_LINE('Deleting');
          rollback;
      END CASE;
    
    end trg_test_insert_select;


    测试结果如下:

    SQL> insert into t_test(a) select sysdate from dual;
     
    1 row inserted
     
    SQL> commit;
     
    Commit complete
     
    SQL> delete from t_test;
     
    delete from t_test
     
    ORA-04092: ROLLBACK 不能在触发器中
    ORA-06512: 在 "SCOTT.TRG_TEST_INSERT_SELECT", line 12
    ORA-04088: 触发器 'SCOTT.TRG_TEST_INSERT_SELECT' 执行过程中出错
     
    SQL> update t_test set a=sysdate+1;
     
    update t_test set a=sysdate+1
     
    ORA-04092: ROLLBACK 不能在触发器中
    ORA-06512: 在 "SCOTT.TRG_TEST_INSERT_SELECT", line 9
    ORA-04088: 触发器 'SCOTT.TRG_TEST_INSERT_SELECT' 执行过程中出错
     
    注意,在应用开发时,需要将这个表的操作进行封装,异常捕获很重要。

  • 相关阅读:
    Docker windows 安装MySql和Tomcat
    Python2 Python3 爬取赶集网租房信息,带源码分析
    BeautifulSoup 一行代码获取今日日期,与smtplib结合
    Python3.x 发送邮件
    Python3 pymysql连接mysql数据库 windows
    urllib2.HTTPError: HTTP Error 403: Forbidden的解决方案
    BeautifulSoup([your markup]) to this: BeautifulSoup([your markup], "lxml") 解决未设置默认解析器的错误
    Python 3.x 中"HTTP Error 403: Forbidden"问题的解决方案
    继承习题
    继承
  • 原文地址:https://www.cnblogs.com/keanuyaoo/p/3395251.html
Copyright © 2011-2022 走看看