系统运维.数据异常.审核人数据丢失问题(单据状态异常问题)排查

【应用场景】
单据中的某个字段的数据无故丢失,原因不明。
例如,采购订单,单据状态为已审核,但是审核人、审核时间字段的数据为空。
需要捕获异常堆栈,判断是什么场景下会产生这样的异常数据。

【排查方法】
<1>新增触发器,捕获到审核人字段数据为零时,抛数据库异常。
IF EXISTS(SELECT * FROM sys.objects WHERE name='TG_PUR_POORDER_FAPPROVERID' AND type='TR') DROP TRIGGER TG_PUR_POORDER_FAPPROVERID GO CREATE TRIGGER TG_PUR_POORDER_FAPPROVERID ON T_PUR_POORDER FOR INSERT,UPDATE AS BEGIN --定义变量 DECLARE @FDOCUMENTSTATUS VARCHAR(20),@FAPPROVERID INT,@FID INT,@FBILLNO NVARCHAR(50),@ERRORMSG NVARCHAR(500) --在inserted表中查询已经插入记录信息 SELECT @FDOCUMENTSTATUS=FDOCUMENTSTATUS,@FAPPROVERID=Inserted.FAPPROVERID,@FID=Inserted.FID,@FBILLNO=ISNULL(Inserted.FBILLNO,'') FROM inserted IF @FDOCUMENTSTATUS='C' AND (@FAPPROVERID IS NULL OR @FAPPROVERID=0)
系统运维.数据异常.审核人数据丢失问题(单据状态异常问题)排查
【应用场景】单据中的某个字段的数据无故丢失,原因不明。例如,采购订单,单据状态为已审核,但是审核人、审核时间字段的数据为空。需要捕...
点击下载文档文档为doc格式
声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。如若本站内容侵犯了原著者的合法权益,可联系本站删除。
上一篇
已经是第一篇



