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