雖然SAP B1有強大的存儲過程控制功能,但經(jīng)測試在單據(jù)打印時是無法觸發(fā)存儲過程的,由于客戶強烈要求無奈之下用了觸發(fā)器來完成該功能(據(jù)說添加觸發(fā)器在升級系統(tǒng)時會報錯,所以升級時可能需要將觸發(fā)器刪掉)。
1、添加自定義字段:U_PrintNum 打印次數(shù);
2、添加用戶界面模板(9.1以后新功能)將“打印次數(shù)”移至單據(jù)中并將其設(shè)置為不可編輯(以防用戶手動修改打印次數(shù)的值);
CREATE TRIGGER ORDR_COMF_NUM ON ORDR /*向ORDR表添加觸發(fā)器,如需向其他單據(jù)添加“打印次數(shù)顯示”功能請修改ORDR至對應(yīng)的表名即可。/ AFTER UPDATE AS BEGIN /*本觸發(fā)器用于記錄銷售訂單打印次數(shù), 要使用此功能需先添加自定義字段“U_PrintNum”用來記錄單據(jù)打印次數(shù) 當[Printed]的值更新為“Y”時 更新銷售訂單上自定義字段“打印次數(shù)”加一, [Printed]的值設(shè)置為“N” */ IF UPDATE([Printed]) /*如果更新的是Printed字段*/ BEGIN UPDATE T0 SET T0.U_PrintNum = ISNULL(T0.U_PrintNum, 0) + 1 , T0.Printed = 'N' FROM ORDR T0 WHERE T0.DocEntry = ( SELECT DocEntry FROM Inserted /*Inserted 表是SQL內(nèi)部表用于存儲INSERT和UPDATE語句所影響的行的副本。*/ ) END END
了解更多SAP B1 信息可點擊>>SAP Business One
2018 廣州工博計算機科技有限公司版權(quán)所有 粵ICP備09030788號 網(wǎng)站地圖