oracle表执行更新操作的时候,那些字段被更新了
2021/9/13 19:08:08
本文主要是介绍oracle表执行更新操作的时候,那些字段被更新了,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
问题要求:每次表执行更新操作的时候,要知道是那些字段被更新了?
解决办法:1、在表上建立触发器,先取得表中有那些字段,可以执行一下语句:
ORACLE:
SELECT COLUMN_NAME FROM USER_TAB_COLUMNS WHERE TABLE_NAME = '表名' ORDER BY COLUMN_ID;
或
SELECT COLUMN_NAME FROM ALL_TAB_COLUMNS WHERE TABLE_NAME = '表名' ORDER BY COLUMN_ID;
注意:表明要区分大小写。
SQLSERVER:
select name from syscolumns where id=object_id('表名');
或
select count(*) from syscolumns where id=object_id('表名');
2、循环字段,看看那些字段被更新了。
循环用for,判断那些字段被更新了,用updating(字段名);
3、触发器完整代码如下
CREATE OR REPLACE TRIGGER TB_TASK_TRGGER
AFTER UPDATE
ON TB_TASK
REFERENCING NEW AS New OLD AS Old
FOR EACH ROW
DECLARE
vrupdate varchar2(100);
BEGIN
vrupdate:='';
FOR TEMPCOLUME IN (SELECT COLUMN_NAME FROM USER_TAB_COLUMNS WHERE TABLE_NAME = 'TB_TASK' ORDER BY COLUMN_ID)
LOOP
IF UPDATING(TEMPCOLUME.COLUMN_NAME)
THEN
dbms_output.put_line(TEMPCOLUME.COLUMN_NAME);
vrupdate:=vrupdate || ',';
END IF;
END LOOP;
UPDATE USERLIST SET duty=vrupdate where userid='1000000386';
EXCEPTION
WHEN OTHERS
THEN
RAISE;
END;
这篇关于oracle表执行更新操作的时候,那些字段被更新了的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-11国产医疗级心电ECG采集处理模块
- 2025-01-10Rakuten 乐天积分系统从 Cassandra 到 TiDB 的选型与实战
- 2025-01-09CMS内容管理系统是什么?如何选择适合你的平台?
- 2025-01-08CCPM如何缩短项目周期并降低风险?
- 2025-01-08Omnivore 替代品 Readeck 安装与使用教程
- 2025-01-07Cursor 收费太贵?3分钟教你接入超低价 DeepSeek-V3,代码质量逼近 Claude 3.5
- 2025-01-06PingCAP 连续两年入选 Gartner 云数据库管理系统魔力象限“荣誉提及”
- 2025-01-05Easysearch 可搜索快照功能,看这篇就够了
- 2025-01-04BOT+EPC模式在基础设施项目中的应用与优势
- 2025-01-03用LangChain构建会检索和搜索的智能聊天机器人指南