日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > windows >内容正文

windows

oracle触发器超过上限,ORACLE系统触发器的疑问,限制IP登录数

發布時間:2025/3/19 windows 57 豆豆
生活随笔 收集整理的這篇文章主要介紹了 oracle触发器超过上限,ORACLE系统触发器的疑问,限制IP登录数 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

本帖最后由 bjddd192 于 2013-12-14 07:26 編輯

CREATE OR REPLACE TRIGGER TRG_LOGON_AUDIT

-----------------------------------------------------------------

--說? ? 明: 限制某個IP到數據庫實例的連接數。如果超過限制會出錯或報警

--建立時間: 2013-10-25 12:10:14

-----------------------------------------------------------------

AFTER LOGON ON DATABASE

DECLARE

V_SESSIONS? ?? ?? ?? ?? ?? ?? ?? ? NUMBER;

V_SESSIONS_LIMITED? ?? ?? ?NUMBER := 2;

V_IP_ADDRESS? ?? ?? ?? ?? ?? ?? ?? ? VARCHAR2(15);

BEGIN

dbms_application_info.set_client_info(sys_context('userenv','ip_address'));

SELECT COUNT(*)

INTO V_SESSIONS

FROM V$SESSION

WHERE CLIENT_INFO = Ora_client_ip_address;

IF (V_SESSIONS > V_SESSIONS_LIMITED) THEN

RAISE_APPLICATION_ERROR(-20001, 'IP:' || V_IP_ADDRESS || '已達最大連接數:'||V_SESSIONS);

END IF;

END TRG_LOGON_AUDIT;

/

我參考網上的例子寫了一個系統觸發器,去限制操作系統用戶登錄數據庫,比如每個人只能連2個,但實際測試時發現用戶還是可以連,只是觸發器的報警在告警日志中可以查看到

D:\oracle\product\10.2.0\admin\orcl\bdump

Errors in file d:\oracle\product\10.2.0\admin\orcl\udump\orcl_ora_1564.trc:ORA-00604: 遞歸 SQL 級別 1 出現錯誤ORA-20003: IP:192.168.244.148已達最大連接數:4ORA-06512: 在 line 20

我想問是是如何讓它不寫告警日志,直接把錯誤返回客戶端不讓登錄呢?初學沒多久,請大俠指點下,謝謝。

以下這個只能限制到Oracle用戶:

SQL>alter system set resource_limit=true;

系統已更改。

SQL>create profile res_limit limit sessions_per_user 50;

配置文件已創建

SQL>alter profile res_limit limit sessions_per_user 3;

配置文件已更改

SQL>alter user yanglei profile res_limit;

用戶已更改。

總結

以上是生活随笔為你收集整理的oracle触发器超过上限,ORACLE系统触发器的疑问,限制IP登录数的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。