oracle 触发器可不可以设置 某个表插入数据时不触发?
我在A表上建立一个insert触发器,如果有新增业务数据插入时就向日志表中写入一条日志记录,但有一个etl程序,定时往A表中插入数据,我想让这个ETL程序插入数据时不触发...
我在A表上建立一个insert触发器,如果有新增业务数据插入时就向日志表中写入一条日志记录,但有一个etl程序,定时往A表中插入数据,我想让这个ETL程序插入数据时不触发,也就是不向日志表中写记录,怎么办?
展开
展开全部
你的ETL程序是什么时候运行?
不定时的?还是集中每天的什么时间段来运行?
如果是定时某一个时间段来运行,可以这么考虑:创建一个job,定时的将这个表中的触发器启动或者禁用。在ETL程序运行的时候,将这个表上面的触发器给禁用。等ETL程序运行完成后,再启用这个触发器。
不知道是否可以满足你的需求。
还可以考虑修改ETL,增加一个功能,插入数据之前,对表中的触发器进行禁用,然后再插入数据,完成之后,再次的启用这个表上的触发器。
还可以根据具体的数据内容来区分哪些是ETL过来的数据,哪些是通过业务系统增加的数据。我想这些数据应该是有一个却别的。可以根据这个区别,将你的触发器修改为字段级别的触发器,而不是行级别的触发器,只有这个表的某一个字段的值,为你想要的值时,才进行触发,否则不触发。当然这种方式就和楼上的说的方案差不多了。
不定时的?还是集中每天的什么时间段来运行?
如果是定时某一个时间段来运行,可以这么考虑:创建一个job,定时的将这个表中的触发器启动或者禁用。在ETL程序运行的时候,将这个表上面的触发器给禁用。等ETL程序运行完成后,再启用这个触发器。
不知道是否可以满足你的需求。
还可以考虑修改ETL,增加一个功能,插入数据之前,对表中的触发器进行禁用,然后再插入数据,完成之后,再次的启用这个表上的触发器。
还可以根据具体的数据内容来区分哪些是ETL过来的数据,哪些是通过业务系统增加的数据。我想这些数据应该是有一个却别的。可以根据这个区别,将你的触发器修改为字段级别的触发器,而不是行级别的触发器,只有这个表的某一个字段的值,为你想要的值时,才进行触发,否则不触发。当然这种方式就和楼上的说的方案差不多了。
追问
恩 谢谢 明白了
展开全部
可以在A表加入一个字段,ETL写入的数据给字段符值0,其他数据写入给字段符值1
在触 发器里判断这个值,如果为1就写日志; 如果为0,就不写日志
在触 发器里判断这个值,如果为1就写日志; 如果为0,就不写日志
追问
恩 谢谢 还有其他办法么?基于数据库方面技术的
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
如果你的ETL程序所在的IP地址是固定的,那你就通过IP地址进行判断,oracle可以获取到客户端连接的IP地址或其他信息
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询