unit U_CPBCKOutPut; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, cxStyles, cxCustomData, cxGraphics, cxFilter, cxData, cxDataStorage, cxEdit, DB, cxDBData, cxCalendar, cxDropDownEdit, ComCtrls, ToolWin, cxGridLevel, cxGridCustomTableView, cxGridTableView, cxGridDBTableView, cxClasses, cxControls, cxGridCustomView, cxGrid, cxGridCustomPopupMenu, cxGridPopupMenu, ADODB, DBClient, cxButtonEdit, cxTextEdit, cxSpinEdit, StdCtrls, ExtCtrls, BtnEdit; type TfrmCPBCKOutPut = class(TForm) ToolBar1: TToolBar; TBSave: TToolButton; TBClose: TToolButton; DataSource3: TDataSource; CDS_Sub: TClientDataSet; ADOQueryCmd: TADOQuery; ADOQueryMain: TADOQuery; ADOQueryTemp: TADOQuery; cxGridPopupMenu2: TcxGridPopupMenu; cxGrid2: TcxGrid; Tv1: TcxGridDBTableView; v1Column6: TcxGridDBColumn; v1Column13: TcxGridDBColumn; v1Column14: TcxGridDBColumn; v2Column1: TcxGridDBColumn; v1Column8: TcxGridDBColumn; v1Column7: TcxGridDBColumn; v1Column1: TcxGridDBColumn; v1Column10: TcxGridDBColumn; v1Column9: TcxGridDBColumn; v2Column6: TcxGridDBColumn; v1Column3: TcxGridDBColumn; v1Column16: TcxGridDBColumn; v1Column12: TcxGridDBColumn; cxGrid2Level1: TcxGridLevel; v1Column5: TcxGridDBColumn; v1Column17: TcxGridDBColumn; v1Column19: TcxGridDBColumn; v1Column4: TcxGridDBColumn; v1Column15: TcxGridDBColumn; v1Column21: TcxGridDBColumn; v1Column22: TcxGridDBColumn; Panel1: TPanel; Label1: TLabel; Label2: TLabel; Label8: TLabel; Label9: TLabel; SQDate: TDateTimePicker; CRType: TComboBox; SQID: TEdit; ToFactoryName: TBtnEditA; ToolBar2: TToolBar; ToolButton2: TToolButton; ToolButton3: TToolButton; procedure FormClose(Sender: TObject; var Action: TCloseAction); procedure TBCloseClick(Sender: TObject); procedure FormShow(Sender: TObject); procedure TBSaveClick(Sender: TObject); procedure v1Column1PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure v1Column5PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); procedure ToolButton1Click(Sender: TObject); procedure ToolButton3Click(Sender: TObject); procedure FormCreate(Sender: TObject); procedure ToFactoryNameBtnClick(Sender: TObject); private { Private declarations } function SaveCKData(): Boolean; procedure CJEWM(MSpid: string); public { Public declarations } FBCId: string; end; var frmCPBCKOutPut: TfrmCPBCKOutPut; implementation uses U_DataLink, U_RTFun, U_ClothContractListHZCX, U_ZDYHelp, U_DJBCKKCSelList, U_GYSSelList, U_ZdyAttachGYS, U_ProductOrderListSel, U_CPBCKKCSel; {$R *.dfm} procedure TfrmCPBCKOutPut.CJEWM(MSpid: string); var Txt, fImagePath, maxNo: string; Moudle: THandle; Makebar: TMakebar; Mixtext: TMixtext; begin try Moudle := LoadLibrary('MakeQRBarcode.dll'); @Makebar := GetProcAddress(Moudle, 'Make'); @Mixtext := GetProcAddress(Moudle, 'MixText'); Txt := Trim(MSpid); fImagePath := ExtractFilePath(Application.ExeName) + 'image\temp.bmp'; if not DirectoryExists(pchar(ExtractFilePath(Application.ExeName) + 'image')) then CreateDirectory(pchar(ExtractFilePath(Application.ExeName) + 'image'), nil); if FileExists(fImagePath) then DeleteFile(fImagePath); Makebar(pchar(Txt), Length(Txt), 3, 3, 0, PChar(fImagePath), 3); with ADOQueryCmd do begin Close; SQL.Clear; SQL.Add('select * from TP_File '); sql.Add('where TFID=' + quotedstr(trim(Txt))); sql.Add('and TFType=''EWM'''); open; if isempty then begin append; fieldbyname('TFID').Value := trim(Txt); fieldbyname('WBID').Value := trim(MSpid); fieldbyname('TFType').Value := 'EWM'; fieldbyname('FillTime').Value := SGetServerDateTime(ADOQueryTemp); tblobfield(FieldByName('Filesother')).LoadFromFile(fImagePath); post; end; end; except application.MessageBox('条形码生成失败!', '提示信息', MB_ICONERROR); exit; end; end; procedure TfrmCPBCKOutPut.FormClose(Sender: TObject; var Action: TCloseAction); begin Action := caFree; end; function TfrmCPBCKOutPut.SaveCKData(): Boolean; var FCRID, Maxno, FSPID, MaxPYNo, FPYID: string; begin try ADOQueryCmd.Connection.BeginTrans; CDS_Sub.DisableControls; with CDS_Sub do begin First; while not eof do begin with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where SPID=''' + Trim(CDS_Sub.fieldbyname('SPID').AsString) + ''''); Open; end; FSPID := Trim(ADOQueryTemp.fieldbyname('SPID').AsString); if Trim(FSPID) = '' then begin if GetLSNo(ADOQueryCmd, Maxno, 'CC', 'CK_SXPB_CR', 3, 1) = False then begin Result := False; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('取待出库编号失败!', '提示', 0); Exit; end; end else begin Maxno := Trim(FSPID); end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where SPID=''' + Trim(Maxno) + ''''); Open; end; with ADOQueryCmd do begin if Trim(FSPID) = '' then begin Append; end else begin Edit; end; FieldByName('SPID').Value := Trim(Maxno); FieldByName('ORDMainIdRK').Value := Trim(CDS_Sub.fieldbyname('ORDMainIdRK').AsString); FieldByName('ORDSubIdRK').Value := Trim(CDS_Sub.fieldbyname('ORDSubIdRK').AsString); FieldByName('ORDMainIdCK').Value := Trim(CDS_Sub.fieldbyname('ORDMainIdCK').AsString); FieldByName('ORDSubIdCK').Value := Trim(CDS_Sub.fieldbyname('ORDSubIdCK').AsString); FieldByName('FZSPID').Value := Trim(CDS_Sub.fieldbyname('FZSPID').AsString); FieldByName('FactoryNo').Value := Trim(CDS_Sub.fieldbyname('FactoryNo').AsString); FieldByName('FromFactoryNo').Value := Trim(CDS_Sub.fieldbyname('FromFactoryNo').AsString); FieldByName('ToFactoryNo').Value := Trim(CDS_Sub.fieldbyname('ToFactoryNo').AsString); //FieldByName('CRID').Value:=CDS_Sub.fieldbyname('CRID').Value; FieldByName('CRFlag').Value := '出库'; FieldByName('CRQtyFlag').Value := -1; RTSetsavedata(ADOQueryCmd, 'CK_SXPB_CR', Panel1, 0); RTSetSaveDataCDS(ADOQueryCmd, Tv1, CDS_Sub, 'CK_SXPB_CR', 2); FieldByName('CKName').Value := '成品布'; if Trim(CDS_Sub.fieldbyname('CRType').AsString) = '平移出库' then begin FieldByName('PYID').Value := Trim(Maxno); end; if Trim(FSPID) = '' then FieldByName('Filler').Value := Trim(DName) else begin FieldByName('Editer').Value := Trim(DName); FieldByName('EditTime').Value := SGetServerDate(ADOQueryTemp); end; FieldByName('Xs').Value := CDS_Sub.fieldbyname('Xs').AsFloat; FieldByName('PiQty').Value := CDS_Sub.fieldbyname('PiQty').AsFloat; FieldByName('Qty').Value := CDS_Sub.fieldbyname('Qty').AsFloat; Post; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('Update CK_SXPB_CR Set MXKCQty=(select sum(isnull(Qty,0)*CRQtyFlag) from CK_SXPB_CR A where A.FZSPID=CK_SXPB_CR.SPID)'); sql.Add(',MXKCPiQty=(select sum(isnull(PiQty,0)*CRQtyFlag) from CK_SXPB_CR A where A.FZSPID=CK_SXPB_CR.SPID)'); sql.Add(' where SPID=''' + Trim(CDS_Sub.fieldbyname('FZSPID').AsString) + ''''); ExecSQL; end; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where SPID=''' + Trim(CDS_Sub.fieldbyname('FZSPID').AsString) + ''''); Open; end; if ADOQueryTemp.FieldByName('MXKCQty').Value < 0 then begin CDS_Sub.DisableControls; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('出库数大于库存数不能保存!', '提示', 0); Exit; end; CJEWM(Maxno); if Trim(CDS_Sub.fieldbyname('CRType').AsString) = '加工出库' then begin with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where PYID=''' + Trim(Maxno) + ''''); sql.Add(' and isnull(CRType,'''')=''平移入库'' '); Open; end; FPYID := Trim(ADOQueryTemp.fieldbyname('SPID').AsString); if Trim(FPYID) = '' then begin if GetLSNo(ADOQueryCmd, MaxPYNo, 'YR', 'CK_SXPB_CR', 3, 1) = False then begin Result := False; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('取外加工平移入库编号失败!', '提示', 0); Exit; end; end else begin MaxPYNo := Trim(FPYID); end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where SPID=''' + Trim(MaxPYNo) + ''''); Open; end; with ADOQueryCmd do begin if Trim(FPYID) = '' then begin Append; end else begin Edit; end; RTSetSaveDataCDS(ADOQueryCmd, Tv1, CDS_Sub, 'CK_SXPB_CR', 2); FieldByName('SPID').Value := Trim(MaxPYNo); FieldByName('ORDMainIdRK').Value := Trim(CDS_Sub.fieldbyname('ORDMainIdCK').AsString); FieldByName('ORDSubIdRK').Value := Trim(CDS_Sub.fieldbyname('ORDSubIdCK').AsString); {FieldByName('ORDMainIdCK').Value:=Trim(CDS_Sub.fieldbyname('ORDMainIdCK').AsString); FieldByName('ORDSubIdCK').Value:=Trim(CDS_Sub.fieldbyname('ORDSubIdCK').AsString);} FieldByName('FZSPID').Value := Trim(MaxPYNo); FieldByName('FactoryNo').Value := Trim(CDS_Sub.fieldbyname('ToFactoryNo').AsString); FieldByName('FromFactoryNo').Value := Trim(CDS_Sub.fieldbyname('FromFactoryNo').AsString); FieldByName('ToFactoryNo').Value := Trim(CDS_Sub.fieldbyname('ToFactoryNo').AsString); FieldByName('CRFlag').Value := '入库'; FieldByName('CRQtyFlag').Value := 1; FieldByName('xs').Value := 0; FieldByName('CKName').Value := '外加工'; FieldByName('CRType').Value := '平移入库'; FieldByName('PYID').Value := Trim(Maxno); if Trim(FPYID) = '' then FieldByName('Filler').Value := Trim(DName) else begin FieldByName('Editer').Value := Trim(DName); FieldByName('EditTime').Value := SGetServerDate(ADOQueryTemp); end; Post; end; with ADOQueryCmd do begin Close; sql.Clear; sql.Add('Update CK_SXPB_CR Set MXKCQty=(select sum(isnull(Qty,0)*CRQtyFlag) from CK_SXPB_CR A where A.FZSPID=CK_SXPB_CR.SPID)'); sql.Add(',MXKCPiQty=(select sum(isnull(PiQty,0)*CRQtyFlag) from CK_SXPB_CR A where A.FZSPID=CK_SXPB_CR.SPID)'); sql.Add(' where SPID=''' + Trim(MaxPYNo) + ''''); ExecSQL; end; with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where SPID=''' + Trim(MaxPYNo) + ''''); Open; end; if ADOQueryTemp.FieldByName('MXKCQty').Value < 0 then begin CDS_Sub.DisableControls; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('出库数大于库存数不能保存!', '提示', 0); Exit; end; end; Edit; FieldByName('SPID').Value := Trim(Maxno); Post; Next; end; end; CDS_Sub.EnableControls; ADOQueryCmd.Connection.CommitTrans; Result := True; except Result := False; ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('保存异常!', '提示', 0); end; end; procedure TfrmCPBCKOutPut.TBCloseClick(Sender: TObject); begin WriteCxGrid('待检布出库登记PMD', Tv1, '待检布工仓库'); Close; end; procedure TfrmCPBCKOutPut.FormShow(Sender: TObject); begin ReadCxGrid('待检布出库登记PMD', Tv1, '待检布仓库'); with ADOQueryTemp do begin Close; sql.Clear; sql.Add(' select A.* '); sql.Add(' ,OrderNo=(select OrderNo from JYOrder_Main JM where JM.MainId=A.OrdMainIdRK )'); sql.Add(' ,OrderNoCK=(select OrderNo from JYOrder_Main JM where JM.MainId=A.OrdMainIdCK )'); sql.Add(' from CK_SXPB_CR A'); sql.Add(' where SPID=''' + Trim(FBCId) + ''''); Open; end; SCreateCDS(ADOQueryTemp, CDS_Sub); SInitCDSData(ADOQueryTemp, CDS_Sub); SCSHData(adoqueryMain, Panel1, 0); end; procedure TfrmCPBCKOutPut.TBSaveClick(Sender: TObject); begin if CDS_Sub.IsEmpty then Exit; if Trim(SQID.Text) = '' then begin Application.MessageBox('申请单号不能为空!', '提示', 0); Exit; end; if Trim(CRType.Text) = '' then begin Application.MessageBox('出库类型不能为空!', '提示', 0); Exit; end; if Trim(ToFactoryName.Text) = '' then begin Application.MessageBox('出到加工厂不能为空!', '提示', 0); Exit; end; if CDS_Sub.Locate('CKOrderNo', null, []) = True then begin Application.MessageBox('出到订单号不能为空!', '提示', 0); Exit; end; if CDS_Sub.Locate('Qty', null, []) = True then begin Application.MessageBox('数量不能为空!', '提示', 0); Exit; end; if CDS_Sub.Locate('PiQty', null, []) = True then begin Application.MessageBox('匹数不能为空!', '提示', 0); Exit; end; CDS_Sub.DisableControls; with CDS_Sub do begin First; while not Eof do begin if Trim(CDS_Sub.fieldbyname('CRType').AsString) = '平移出库' then begin if (Trim(CDS_Sub.fieldbyname('FromFactoryName').AsString) = Trim(CDS_Sub.fieldbyname('ToFactoryName').AsString)) and (Trim(CDS_Sub.fieldbyname('ORDSubIdRK').AsString) = Trim(CDS_Sub.fieldbyname('ORDSubIdCK').AsString)) then begin CDS_Sub.EnableControls; Application.MessageBox('同一单号,同一工厂不能平移数据!', '提示', 0); Exit; end; end; Next; end; end; CDS_Sub.EnableControls; if SaveCKData() then begin Application.MessageBox('保存成功!', '提示', 0); //ModalResult:=1; Exit; end; end; procedure TfrmCPBCKOutPut.v1Column1PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmClothContractListHZCX := TfrmClothContractListHZCX.Create(Application); with frmClothContractListHZCX do begin if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('CGConNo').Value := Trim(frmClothContractListHZCX.Order_Main.fieldbyname('ConNo').AsString); FieldByName('CGConMainId').Value := Trim(frmClothContractListHZCX.Order_Main.fieldbyname('MainId').AsString); FieldByName('CGConSubId').Value := Trim(frmClothContractListHZCX.Order_Main.fieldbyname('SubId').AsString); FieldByName('FactoryName').Value := Trim(frmClothContractListHZCX.Order_Main.fieldbyname('FactoryNoName').AsString); FieldByName('SXName').Value := Trim(frmClothContractListHZCX.Order_Main.fieldbyname('C_CodeName').AsString); //Post; end; end; end; finally frmClothContractListHZCX.Free; end; end; procedure TfrmCPBCKOutPut.v1Column5PropertiesButtonClick(Sender: TObject; AButtonIndex: Integer); begin try frmProductOrderListSel := TfrmProductOrderListSel.Create(Application); with frmProductOrderListSel do begin if ShowModal = 1 then begin with Self.CDS_Sub do begin Edit; FieldByName('ORDMainIdCK').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('MainId').AsString); FieldByName('ORDSubIdCK').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('SubId').AsString); FieldByName('CKorderNo').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('OrderNo').AsString); FieldByName('PRTColor').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('PRTColor').AsString); FieldByName('PRTHX').Value := Trim(frmProductOrderListSel.Order_Main.fieldbyname('PRTHX').AsString); end; end; end; finally frmProductOrderListSel.Free; end; end; procedure TfrmCPBCKOutPut.ToolButton1Click(Sender: TObject); begin try frmCPBCKKCSel := TfrmCPBCKKCSel.Create(Application); with frmCPBCKKCSel do begin ToolButton1.Visible := True; if ShowModal = 1 then begin frmCPBCKKCSel.CDS_Main.DisableControls; with frmCPBCKKCSel.CDS_Main do begin First; while Locate('SSel', True, []) do begin with Self.CDS_Sub do begin Append; // FieldByName('CRTime').Value := Trim(FormatDateTime('yyyy-MM-dd', Now)); FieldByName('ORDMainIdRK').Value := Trim(frmCPBCKKCSel.CDS_Main.fieldbyname('ORDMainIdRK').AsString); FieldByName('ORDSubIdRK').Value := Trim(frmCPBCKKCSel.CDS_Main.fieldbyname('ORDSubIdRK').AsString); FieldByName('ORDMainIdCK').Value := Trim(frmCPBCKKCSel.CDS_Main.fieldbyname('ORDMainIdRK').AsString); FieldByName('ORDSubIdCK').Value := Trim(frmCPBCKKCSel.CDS_Main.fieldbyname('ORDSubIdRK').AsString); FieldByName('QCOrderNo').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('OrderNo').Value; FieldByName('CKOrderNo').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('OrderNo').Value; FieldByName('CustomerNoName').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('CustomerNoName').AsString; FieldByName('spcode').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('spcode').AsString; FieldByName('SPColor').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('SPColor').AsString; FieldByName('SPHX').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('SPHX').AsString; FieldByName('FactoryName').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('FactoryName').Value; FieldByName('FactoryNo').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('FactoryNo').Value; FieldByName('SSType').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('SSType').Value; FieldByName('SPName').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('SPName').Value; FieldByName('SPSpec').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('SPSpec').Value; FieldByName('SPCF').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('SPCF').Value; FieldByName('SPMF').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('SPMF').Value; FieldByName('SPKZ').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('SPKZ').Value; FieldByName('RCGangNo').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('RCGangNo').Value; FieldByName('FromFactoryName').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('ToFactoryName').Value; FieldByName('FromFactoryNo').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('ToFactoryNo').Value; FieldByName('ToFactoryName').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('ToFactoryName').Value; FieldByName('ToFactoryNo').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('ToFactoryNo').Value; FieldByName('QtyUnit').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('QtyUnit').Value; FieldByName('PiQty').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('MXKCPiQty').Value; FieldByName('Qty').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('MXKCQty').Value; FieldByName('FZSPID').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('SPID').Value; FieldByName('Note').Value := frmCPBCKKCSel.CDS_Main.fieldbyname('Note').Value; end; frmCPBCKKCSel.CDS_Main.Delete; end; end; frmCPBCKKCSel.CDS_Main.EnableControls; end; end; finally frmDJBCKKCSelList.Free; end; end; procedure TfrmCPBCKOutPut.ToolButton3Click(Sender: TObject); begin if CDS_Sub.IsEmpty then Exit; if Trim(CDS_Sub.fieldbyname('SPID').AsString) <> '' then begin with ADOQueryTemp do begin Close; sql.Clear; sql.Add('select * from CK_SXPB_CR where FZSPID='); sql.Add('(select SPID from CK_SXPB_CR where PYID=''' + Trim(CDS_Sub.fieldbyname('SPID').AsString) + ''''); sql.Add(' and isnull(CRType,'''')=''平移入库'')'); sql.Add(' and CRQtyFlag=-1'); Open; end; if ADOQueryTemp.IsEmpty = False then begin Application.MessageBox('已有出库记录,不能删除!', '提示', 0); Exit; end; if Application.MessageBox('确定要删除数据吗?', '提示', 32 + 4) <> IDYES then Exit; try ADOQueryCmd.Connection.BeginTrans; with ADOQueryCmd do begin Close; sql.Clear; sql.Add(' delete CK_SXPB_CR where SPID=''' + Trim(CDS_Sub.fieldbyname('SPID').AsString) + ''''); sql.Add(' Update CK_SXPB_CR Set MXKCQty=(select sum(isnull(Qty,0)*CRQtyFlag) from CK_SXPB_CR A where A.FZSPID=CK_SXPB_CR.SPID)'); sql.Add(',MXKCPiQty=(select sum(isnull(PiQty,0)*CRQtyFlag) from CK_SXPB_CR A where A.FZSPID=CK_SXPB_CR.SPID)'); sql.Add(' where SPID=''' + Trim(CDS_Sub.fieldbyname('FZSPID').AsString) + ''''); {sql.Add('Update CK_SXPB_KC Set KCKGQty=(select sum(KGQty*CRQtyFlag) from CK_SXPB_CR A where A.CRID=CK_SXPB_KC.CRID)'); sql.Add(',KCPiQty=(select sum(PiQty*CRQtyFlag) from CK_SXPB_CR A where A.CRID=CK_SXPB_KC.CRID)'); sql.Add(' where CRID='+Trim(CDS_Sub.fieldbyname('CRID').AsString)); } ExecSQL; end; ADOQueryCmd.Connection.CommitTrans; except ADOQueryCmd.Connection.RollbackTrans; Application.MessageBox('删除异常!', '提示', 0); end; end; CDS_Sub.Delete; end; procedure TfrmCPBCKOutPut.FormCreate(Sender: TObject); begin SQDate.Date := SGetServerDate(ADOQueryTemp); end; procedure TfrmCPBCKOutPut.ToFactoryNameBtnClick(Sender: TObject); begin try frmZdyAttachGYS := TfrmZdyAttachGYS.Create(Application); with frmZdyAttachGYS do begin if ShowModal = 1 then begin with Self.CDS_Sub do begin edit; FieldByName('ToFactoryNo').Value := Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('COCode').AsString); // FieldByName('ToFactoryName').Value := Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('COName').AsString); //Post; end; ToFactoryName.Text := Trim(frmZdyAttachGYS.CDS_HZ.fieldbyname('COName').AsString); end; end; finally frmZdyAttachGYS.Free; end; end; end.