oracle sysdate 由于事务时间过长导致插入数据库的数据时间不对的问题 50
公司遇到这种情况:有个申请单的表,由于更新操作业务时间长导致锁表,同时又有新的申请单提交,所以以后新的申请单都需要等待事务。当然用户量大的情况下才会出现上述问题,上述问题...
公司遇到这种情况:有个申请单的表,由于更新操作业务时间长导致锁表,同时又有新的申请单提交,所以以后新的申请单都需要等待事务。
当然用户量大的情况下才会出现上述问题,上述问题本不影响业务,影响业务的是时间。因为业务对时间要求比较严谨,由于长时间事务等待导致插入数据库的时间字段与实际提交不等。
以下举例说明情况
假如有申请单表 sj_sqd
操作1:
update sj_sqd set name = '更新申请单'
此操作更新了申请单,但是业务时间很长,一直没有提交,极端一点,10分钟。
操作2:
操作2在操作1后,但几乎同时进行。操作2是一条插入语句(假如此时时间为:2018年2月22日16:18:44):
insert into sj_sqd (id,name,tisj)values(1,'插入申请单',sysdate)
此时提交事务,但由于操作1事务导致的锁表,此操作需要等待操作1完毕后才能插入。
10分钟后,操作1执行完毕了,操作2也开始写入。但问题来了,我希望操作2插入数据库的时间是10分钟后的时间,也就是实际提交事务时的时间,而不是之前的2018年2月22日16:18:44。请问这种该如何实现呢? 展开
当然用户量大的情况下才会出现上述问题,上述问题本不影响业务,影响业务的是时间。因为业务对时间要求比较严谨,由于长时间事务等待导致插入数据库的时间字段与实际提交不等。
以下举例说明情况
假如有申请单表 sj_sqd
操作1:
update sj_sqd set name = '更新申请单'
此操作更新了申请单,但是业务时间很长,一直没有提交,极端一点,10分钟。
操作2:
操作2在操作1后,但几乎同时进行。操作2是一条插入语句(假如此时时间为:2018年2月22日16:18:44):
insert into sj_sqd (id,name,tisj)values(1,'插入申请单',sysdate)
此时提交事务,但由于操作1事务导致的锁表,此操作需要等待操作1完毕后才能插入。
10分钟后,操作1执行完毕了,操作2也开始写入。但问题来了,我希望操作2插入数据库的时间是10分钟后的时间,也就是实际提交事务时的时间,而不是之前的2018年2月22日16:18:44。请问这种该如何实现呢? 展开
2个回答
展开全部
可以用触发器,当有新纪录插入时,写入当时的时间。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询