亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? lmp_rkfh.pas

?? 省級集郵品管理ERP
?? PAS
?? 第 1 頁 / 共 2 頁
字號:

{*******************************************************}
{                                                       }
{                     零枚票入庫審核                    }
{                                                       }
{            中軟金馬公司版權所有。2002.12前            }
{                                                       }
{               編制:中軟金馬項目開發組                }
{                                                       }
{                                                       }
{*******************************************************}
(*
本模塊在省級庫房管理模塊 零枚票部分的入庫審核菜單調用。
*)
{
[與零枚票對照]
  表對照
    A 零枚票發貨單         -> 集郵票品發貨單
    B 零枚出庫票品         -> 集郵出庫票品
    C 袋數重量表           -> 集郵袋數重量表
    D 包號版號表(出庫單)  -> 集郵包號版號(出庫單)
  字段對照
    B
     圖代碼 -> 票品代碼
     售價   -> 銷價
     面值   -
     原價   +
     進價   +
    D
     進價   +

有關表:
  集郵票品發貨單、集郵出庫票品、集郵袋數重量表、集郵包號版號(出庫單)
數據來源:
  出庫單計劃號:集郵票品發貨單依據單號的GROUP BY
  發貨單號:  集郵票品發貨單的發貨單號
  發貨單主信息:集郵票品發貨單
  發貨單詳細信息:集郵出庫票品
  包袋:集郵袋數重量表
  包號版本號:集郵包號版號(出庫單)
功能:
算法:
  1.輸入的庫房號必須在庫房表中存在
  2.對起始版號、終止版本號數據修改時要較驗,即不能重復
  3.當修改完成保存數據時,需要作如下操作:
    A. 裝票日期、封裝袋數、出庫日期、庫管員、備注保存到集郵票品發貨單中
       修改集郵票品發貨單的在途狀態為'1'
    B. 記錄庫存數據
      零枚票品庫存
        票品代碼:集郵出庫票品.票品代碼
        庫房代碼:集郵出庫票品.庫房號
        原價:集郵出庫票品.原價
        進價:集郵出庫票品.進價
        銷價:集郵出庫票品.銷價
        庫位號:集郵出庫票品.庫位號
        票品類別:通過票品代碼判斷(?)
        IF 出庫性質 = '待銷毀出庫' THEN
          待銷毀庫存 = 待銷毀庫存 - 集郵出庫票品.數量
        ELSE IF 出庫性質 = '預付出庫' THEN
          預付庫存 = 預付庫存 - 集郵出庫票品.數量
        ELSE 庫存總枚數 = 庫存總枚數 + 集郵出庫票品.數量
        變更標志:NULL(?)
        備注:NULL
      包號版號表(庫存)
        起始版號:包號版號表(出庫單).起始版本號
        終止版號: 包號版號表(出庫單).終止版本號
    C. 記帳
        集郵票總帳表
        集郵票總分戶帳表  (集郵票總分戶帳明細表)
        集郵票明細分類帳
        集郵票進發存明細帳表
        集郵票明細分類帳(庫管員)
        集郵票品庫存(庫管)
        集郵票品庫存(業務部)
更新有關表:
  集郵票品發貨單、集郵出庫票品、集郵袋數重量表、集郵包號版號(出庫單)
備注:
  對操作員要較驗權限,不能瀏覽其它庫房的入庫單
}
unit LMP_RKFH;

interface

uses
  Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
  FORMBASE, ExtCtrls, ModiPanel, StdCtrls, Mask, DBCtrls, Grids, DBGrids,
  CurrEdit, RXDBCtrl, ToolEdit, ComCtrls, Buttons, DBTables, Db,
  RxQuery, sqlstrings, RXCtrls;

type
  TFrm_LMP_RKFH = class(TFFormBase)
    ModiPanel1: TModiPanel;
    Panel1: TPanel;
    DBGrid2: TDBGrid;
    Panel2: TPanel;
    Label2: TLabel;
    Label3: TLabel;
    Label4: TLabel;
    Label5: TLabel;
    DBEdit2: TDBEdit;
    DBEdit3: TDBEdit;
    DBEdit4: TDBEdit;
    DBEdit6: TDBEdit;
    DBDateEdit1: TDBDateEdit;
    Label10: TLabel;
    UpdateSQL1: TUpdateSQL;
    DataSource2: TDataSource;
    qryRKDPP: TQuery;
    UpdateSQL2: TUpdateSQL;
    DataSource3: TDataSource;
    qryBHBH: TQuery;
    UpdateSQL4: TUpdateSQL;
    DataSource5: TDataSource;
    DBGrid4: TDBGrid;
    BitBtn1: TBitBtn;
    BitBtn2: TBitBtn;
    DBGrid3: TDBGrid;
    qryRKD: TRxQuery;
    BitBtn5: TBitBtn;
    StoredProc1: TStoredProc;
    Label12: TLabel;
    qryRKDPPRKDH: TStringField;
    qryRKDPPPPDM: TStringField;
    qryRKDPPKFDM: TStringField;
    qryRKDPPKWH: TStringField;
    qryRKDPPMZ: TFloatField;
    qryRKDPPSJ: TFloatField;
    qryRKDPPSL: TFloatField;
    qryRKDPPBZ: TStringField;
    qryRKDPPZH: TStringField;
    qryRKDPPTJC: TStringField;
    qryRKDPPKFMC: TStringField;
    Panel3: TPanel;
    XttxTitle: TRxLabel;
    DWMC: TLabel;
    Label8: TLabel;
    BitBtn7: TBitBtn;
    DateEdit1: TDateEdit;
    BitBtn6: TBitBtn;
    DBEdit1: TDBEdit;
    Qryban: TQuery;
    QrybanTDM: TStringField;
    QrybanBLSH: TFloatField;
    QrybanBJC: TStringField;
    DS_ban: TDataSource;
    qryBHBHRKDH: TStringField;
    qryBHBHPPDM: TStringField;
    qryBHBHQSBH: TStringField;
    qryBHBHZZBH: TStringField;
    qryBHBHZH: TStringField;
    qryBHBHTJC: TStringField;
    qryBHBHBLSH: TFloatField;
    qryBHBHbz: TStringField;
    procedure ModiPanel1BtnClick(Index: TBtnVisible);
    procedure FormClose(Sender: TObject; var Action: TCloseAction);
    procedure FormCreate(Sender: TObject);
    procedure BitBtn1Click(Sender: TObject);
    procedure BitBtn2Click(Sender: TObject);
    procedure qryBHBHAfterInsert(DataSet: TDataSet);
    procedure BitBtn5Click(Sender: TObject);
    procedure qryRKDUpdateError(DataSet: TDataSet; E: EDatabaseError;
      UpdateKind: TUpdateKind; var UpdateAction: TUpdateAction);
    procedure qryRKDPPUpdateError(DataSet: TDataSet; E: EDatabaseError;
      UpdateKind: TUpdateKind; var UpdateAction: TUpdateAction);
    procedure qryBHBHUpdateError(DataSet: TDataSet; E: EDatabaseError;
      UpdateKind: TUpdateKind; var UpdateAction: TUpdateAction);
    procedure qryRKDPPMZGetText(Sender: TField; var Text: string;
      DisplayText: Boolean);
    procedure qryRKDPPMZSetText(Sender: TField; const Text: string);
    procedure DBGrid2DrawColumnCell(Sender: TObject; const Rect: TRect;
      DataCol: Integer; Column: TColumn; State: TGridDrawState);
    procedure BitBtn6Click(Sender: TObject);
    procedure BitBtn7Click(Sender: TObject);
    procedure qryRKDAfterScroll(DataSet: TDataSet);
  private
    { Private declarations }
    FDtState: TDataState;
    function Save: Boolean;
    procedure SetState(Value: TdataState);
    procedure InitData;
    function check(id: string): boolean;
  public
    { Public declarations }
  end;

function Show_LMP_RKFH: Boolean;
var
  Frm_LMP_RKFH: TFrm_LMP_RKFH;

implementation

uses
  datas, Pub,
  LMP_RKFH_Print;                                           {零枚票入庫復核打印}

{$R *.DFM}

function Show_LMP_RKFH: Boolean;
begin
  Result := false;
  Application.CreateForm(TFrm_LMP_RKFH, Frm_LMP_RKFH);
  with Frm_LMP_RKFH do
  try
    if CheckRight(Frm_LMP_RKFH, [ModiPanel1, BitBtn5, BitBtn6]) then
      result := ShowModal = MB_OK;
  finally
    Free;
  end;
end;

procedure TFrm_LMP_RKFH.SetState(Value: TdataState);
var
  v_b_modiBHBH: boolean;                                    //是否只修改包號版號(修改已復核過的出庫單包號版號)
  procedure SetControls(Value: Boolean);
  begin
    Panel1.Enabled := Value;
    DBEdit1.ReadOnly := Value or v_b_modiBHBH;
    DBDateEdit1.ReadOnly := Value or v_b_modiBHBH;
    DBGrid4.ReadOnly := Value;
    DBGrid3.ReadOnly := Value;
    BitBtn1.Enabled := not (Value);
    BitBtn2.Enabled := not (Value);
    BitBtn5.Enabled := Value and not (qryRKD.IsEmpty or qryRKDPP.isempty);
    BitBtn6.Enabled := Value and not (qryRKD.IsEmpty or qryRKDPP.isempty);
  end;
begin
  v_b_modiBHBH := false;
  if not qryRKD.Active then
  begin
    FDtState := dtBrowse;
    ModiPanel1.ChangeMode(FDtState = dtBrowse);
    SetControls(FDtState = dtBrowse);
    exit;
  end;

  if (Value in [dtEdit, dtInsert]) and
    isChecked(io_txp, false, qryRKD.FieldbyName('rkdh').Asstring) then
  begin
    if qryRKD.FieldbyName('JZY').AsString <> VG_UserName then
    begin
      CHQMsgBox('對不起,您只能修改自己的入庫單');
      exit;
    end
    else
      v_b_modiBHBH := true;
  end;

  FDtState := Value;
  ModiPanel1.ChangeMode(FDtState = dtBrowse);
  SetControls(FDtState = dtBrowse);
  with qryRKD do
    case FDtstate of
      dtBrowse:
        begin
          {          qryRKDPP.Datasource := DataSource2;
                    qryBHBH.Datasource := DataSource2;}
        end;
      dtinsert:
        begin
          Append;
          {          qryRKDPP.Datasource := nil;
                    qryBHBH.Datasource := nil;}
        end;
      dtedit:
        begin
          if not v_b_modiBHBH then
          begin
            {            qryRKDPP.Datasource := nil;
                        qryBHBH.Datasource := nil;}
            Edit;
            if FieldByName('RKRQ').AsString = '' then
              FieldByName('RKRQ').AsDateTime := GetSYSDate;
          end
          else if qryBHBH.IsEmpty then
          begin
            qryRKDPP.First;
            while not qryRKDPP.Eof do
            begin
              qryBHBH.Append;
              qryBHBH.FieldByName('RKDH').Asstring := qryRKD.FieldByName('RKDH').Asstring;
              qryBHBH.FieldByName('PPDM').Asstring := qryRKDPP.FieldByName('PPDM').Asstring;
              qryBHBH.FieldByName('ZH').Asstring := qryRKDPP.FieldByName('ZH').Asstring;
              qryBHBH.FieldByName('TJC').Asstring := qryRKDPP.FieldByName('TJC').Asstring;
              qryBHBH.Post;
              qryRKDPP.Next;
            end;
          end;
        end;
    end;
end;

function TFrm_LMP_RKFH.Save: Boolean;
begin
  result := True;
  with qryBHBH do                                           {query}
  begin
    First;
    while not Eof do
    begin                                                   //RKDH, PPDM, QSBH, ZZBH
      if (FieldByName('RKDH').Asstring = '') or (FieldByName('PPDM').Asstring = '')
        or (FieldByName('QSBH').Asstring = '') or (FieldByName('ZZBH').Asstring = '') then
      begin
        CHQMsgBox('起始版號、終止版號不能為空!');
        result := False;
        Break;
      end;
      Next;
    end;
  end;
  if not result then
    exit;

  with qryRKD do                                            {query}
  begin
    Database.StartTransaction;
    try
      qryRKD.ApplyUpdates;
      qryRKDPP.ApplyUpdates;
      qryBHBH.ApplyUpdates;
      Database.Commit;
    except
      if Database.InTransaction then
        Database.RollBack;
      if errMsg = '' then
        raise
      else
        raise exception.Create(errMsg);
    end;
  end;
  qryRKD.CommitUpdates;
  qryRKDPP.CommitUpdates;
  qryBHBH.CommitUpdates;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品18久久久久久久久 | 日本精品一级二级| 大陆成人av片| 一本色道综合亚洲| 欧美一级日韩免费不卡| 欧美日韩精品三区| 国产丝袜在线精品| 午夜精品国产更新| aaa国产一区| 精品蜜桃在线看| 中国av一区二区三区| 亚洲一区二区三区四区中文字幕| 麻豆成人免费电影| 免费精品视频在线| 久久精品久久精品| 欧美视频日韩视频| 欧美国产精品劲爆| 亚洲小说春色综合另类电影| 99精品偷自拍| 久久一夜天堂av一区二区三区| 五月天欧美精品| 成人av影视在线观看| 26uuu另类欧美| 婷婷亚洲久悠悠色悠在线播放| 久久99精品久久只有精品| 精品视频一区三区九区| 国产精品国产三级国产aⅴ中文| 日本中文一区二区三区| 色菇凉天天综合网| 国产亲近乱来精品视频| 成人性生交大片免费看视频在线| 精品国产乱子伦一区| 1000精品久久久久久久久| 日本美女一区二区三区| 制服.丝袜.亚洲.中文.综合| 亚洲国产成人av好男人在线观看| 成人午夜电影久久影院| 亚洲精品ww久久久久久p站| 欧美亚洲免费在线一区| 免费欧美日韩国产三级电影| 国产一区欧美二区| 日韩一级高清毛片| 亚洲国产日韩精品| 26uuu亚洲婷婷狠狠天堂| 国产成人精品一区二区三区网站观看| 久久久国产午夜精品| 美脚の诱脚舐め脚责91 | 日韩一区二区三区免费看| 久久精品国产亚洲aⅴ| 欧美日韩在线一区二区| 久久精品国产99久久6| 久久精品亚洲麻豆av一区二区| 五月婷婷欧美视频| 美女视频黄 久久| 欧美一区二区国产| 亚洲高清在线精品| 欧美视频在线一区| 亚洲国产精品t66y| 成人激情av网| 亚洲一区日韩精品中文字幕| 欧美日韩国产小视频在线观看| 伊人色综合久久天天| 色狠狠综合天天综合综合| 亚洲午夜在线视频| 日韩一区二区精品| 国产成人精品三级麻豆| 蜜臀久久99精品久久久久宅男 | 久久久亚洲午夜电影| 欧美无砖砖区免费| 国产资源精品在线观看| 亚洲欧美日韩在线| 99久久久久久| 日本欧美一区二区| 日韩一级高清毛片| 精品亚洲国产成人av制服丝袜| 中文一区二区完整视频在线观看| 欧美日韩黄色一区二区| 99riav一区二区三区| 亚洲电影中文字幕在线观看| 国产女同互慰高潮91漫画| 欧美一级欧美一级在线播放| 一本在线高清不卡dvd| 懂色一区二区三区免费观看| 免费一级欧美片在线观看| 国产精品毛片久久久久久久| 国产精品久久午夜夜伦鲁鲁| 2欧美一区二区三区在线观看视频| 日韩无一区二区| 日韩三区在线观看| 精品国产亚洲在线| 欧美成人精品高清在线播放| 69p69国产精品| 欧美日韩亚洲不卡| 久久精品人人做人人综合 | 日韩丝袜美女视频| 精品少妇一区二区三区| 538在线一区二区精品国产| 欧美精品视频www在线观看| 91麻豆精品秘密| 在线一区二区三区四区| 成人av动漫网站| 国产精品白丝jk黑袜喷水| 国产福利精品导航| 91视频国产观看| 91精品国产色综合久久不卡蜜臀 | 在线欧美一区二区| 欧美变态凌虐bdsm| 国产精品色哟哟网站| 日韩精品电影在线观看| 91精品国产综合久久香蕉麻豆| 欧美另类z0zxhd电影| www.欧美亚洲| zzijzzij亚洲日本少妇熟睡| 91免费小视频| 91精品国产手机| 美女一区二区久久| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲精选视频免费看| 五月婷婷激情综合| 毛片一区二区三区| 欧美亚洲国产一卡| 日韩精品在线看片z| 国产精品久久久久9999吃药| 亚洲九九爱视频| 日本 国产 欧美色综合| 激情另类小说区图片区视频区| 久久不见久久见免费视频1| 制服视频三区第一页精品| |精品福利一区二区三区| 亚洲aⅴ怡春院| 国产成人丝袜美腿| 一本色道综合亚洲| 久久精品人人做人人爽人人| 亚洲成人你懂的| 国产成人亚洲综合a∨猫咪| 日本不卡在线视频| 欧洲av一区二区嗯嗯嗯啊| 日韩欧美自拍偷拍| 轻轻草成人在线| 色94色欧美sute亚洲线路一久| 精品国产乱码久久久久久久| 亚洲成a人片在线观看中文| 91日韩在线专区| 亚洲四区在线观看| 国产麻豆精品95视频| 91麻豆精品国产91久久久久久 | 看电视剧不卡顿的网站| 欧美性大战久久久久久久蜜臀| 91精品国产欧美日韩| 日韩福利视频网| 欧美高清dvd| 国产精品蜜臀av| 久久精品国产一区二区| 91精品久久久久久久久99蜜臂 | 这里只有精品电影| 一区二区三区不卡视频| www.久久久久久久久| 日韩一区二区免费视频| 亚洲免费在线播放| 欧美午夜免费电影| 中文字幕一区二区三区在线不卡 | 日本色综合中文字幕| 欧美性猛交一区二区三区精品| 中文字幕在线不卡一区二区三区 | 亚洲综合999| 欧美日韩亚洲国产综合| 国产拍揄自揄精品视频麻豆| 成人免费精品视频| 亚洲成人动漫av| 欧美美女一区二区| 亚洲午夜在线电影| 精品国产百合女同互慰| 色网站国产精品| 国产精品动漫网站| 欧美日韩一区国产| 大陆成人av片| 国产精品久久久久久久久久久免费看 | 日韩一区二区三| 亚洲成人免费视| 欧美国产视频在线| 欧美夫妻性生活| 国产aⅴ精品一区二区三区色成熟| 亚洲国产激情av| 欧美视频一区二区三区四区| 亚洲.国产.中文慕字在线| 国产日韩欧美高清| 欧美一级生活片| 91丨porny丨在线| 国产一区久久久| 国产午夜亚洲精品不卡 | 国产精品综合av一区二区国产馆| 亚洲婷婷综合色高清在线| 欧美色图天堂网| 久久99久久精品| 午夜久久久影院| 樱花影视一区二区| 国产精品国产自产拍高清av | 日本道精品一区二区三区| 午夜精品久久久久久久99水蜜桃| 精品国产免费久久|