文章详情

短信预约信息系统项目管理师 报名、考试、查分时间动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

在plsql字符串拼接,批量生成trigger

2017-04-22 03:37

关注

在plsql字符串拼接,批量生成trigger

本次需要批量编写监控全数据库表的trigger,记录下变更的字段名和变更的值、表名、相对应的主键和做的操作(增删改)。在自动生成脚本sql后,执行execute

immediate sql_str --date:2021-11-05
  1. 通过 || 拼接字符串。
  2. 通过user_cons_columns , user_constraints 来获取表的主键。以CONSTRAINT_TYPE 选定主键类型,以TABLE_NAME绑定表名,从而获取表的主键名,为后续拼接获取表主键和主键值做准备。最后,将该表所有主键名存放于var_array (防止组合主键),后续能够遍历取出
  3. 通过表user_tab_columns 获取表所有字段,后续拼接查看值的更新。
  4. 通过new.column <> old.column 来判断前后值是否变更,如若变更,记录下变更的值。
  5. if deleting,inserting,updating来判断执行的操作。
  6. 最后,生成的trigger将向我们新建的存储表插入执行的操作,变更的列名,变更的值以及主键,以便于我们检索。
  7. 同理,可生成批量启动和关闭trigger的脚本。

(1)首先获取数据库中所有表的表名

for tables_name in (
select table_name
from user_tables
) loop

(2)根据约束表,获取各表的主键--需求需要

for primary_key in (
select cu.COLUMN_NAME from user_cons_columns cu , user_constraints au
where cu.constraint_name = au.CONSTRAINT_NAME
and au.CONSTRAINT_TYPE = "P"
and au.TABLE_NAME= tables_name.table_name
)loop
i:=i+1;
var_array(i):=primary_key.column_name;
end loop;

(3)trigger在插入修改和删除前触发

-- the first set sql_str
sql_str := "create or replace trigger "||" task_for_link_"||tables_name.table_name||
" before insert or update or delete"||
" on "||tables_name.table_name||
" for each row"||
" declare "||
"jobName varchar2(200);"||
"tableName varchar2(200);"||
"columnName varchar2(200);"||
"str varchar2(2000);"||
"pk_information varchar2(300);"||
" begin "||
"tableName := """||tables_name.table_name||""";";

for primary_key_count in 1..var_array.count loop
sql_str := sql_str||
"pk_information := """||var_array(primary_key_count)||"""||:new."||var_array(primary_key_count)||";";
end loop;
var_array.delete();
i:=0;
sql_str := sql_str||
"if updating then";

 

(4)拼接,判断字段是否有变更,如若有记录下来

-- get every column_name by table_name
for columns_name in (
select t.table_name,t.column_name
from user_tab_columns t
where t.TABLE_NAME = tables_name.table_name
) loop
-- the second set column to sql_str

sql_str := sql_str||
" if :new."||columns_name.column_name||" <> :old."||columns_name.column_name||" then"||
" str := str||"""||columns_name.column_name||""";"||
"end if;";
end loop;
-- the third set the whole sql_str
sql_str := sql_str||
" insert into t_task ( JOB_NAME, TABLE_NAME, COLUMN_NAME , pk_information)"||
" values ( ""update"", tableName, str, pk_information);"||
" end if;"||
" if inserting then"||
" insert into t_task ( JOB_NAME, TABLE_NAME, COLUMN_NAME, pk_information)"||
" values ( ""insert"", tableName, columnName, pk_information); "||
" end if;"||
" if deleting then"||
" insert into t_task ( JOB_NAME, TABLE_NAME, COLUMN_NAME, pk_information)"||
" values ( ""delete"", tableName, columnName, pk_information); "||
" end if;"||
"end task_for_link_"||table_name||";";

 

(5)执行脚本--when other then null(抛错继续执行)

begin
execute immediate sql_str;
exception
when others then null;
end;
dbms_output.put_line(sql_str);
end loop;
end;

 

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯