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

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

?? datamodule.pas

?? 圖書管理系統
?? PAS
?? 第 1 頁 / 共 2 頁
字號:
unit DataModule;

interface

uses
  SysUtils, Classes, DB, ADODB,Forms,variants,Dialogs;

type
  TDM = class(TDataModule)
    ADOConnection1: TADOConnection;
    ADODataSetBookEdit: TADODataSet;
    DataSource1: TDataSource;
    ADODataSet2: TADODataSet;
    ADODataSetLendBook: TADODataSet;
    DataSourceLendBook: TDataSource;
    ADODataSetBookType: TADODataSet;
    DataSourceBookType: TDataSource;
    ADODataSetBookQuery: TADODataSet;
    ADODataSetBookStockQuery: TADODataSet;
    ADODataSetReaderQuery: TADODataSet;
    ADODataSetLendBookQuery: TADODataSet;
    ADODataSetUserQuery: TADODataSet;
  private
    { Private declarations }
  public
    { Public declarations }
    procedure InitAdoDatasetBookEdit;
    function CCheckBookNumber(bookid:string):boolean; //根據書ID獲得書數
    function CCheckID(sql:string):boolean;            //傳入SQL檢測ID是否存在(通用)
    function GetBookName(bookid:string):string;       //根據書ID獲得書名
    function InsertBookType(value1,value2:string):boolean;
    function UpdateBookType(value1,value2:string):boolean;
    function DeleteBookType(bookid:string):boolean;   //刪除圖書類型
    function GetBookTypeNum(value:string):integer;  //獲得某類圖書在庫中總數
    function GetBookTypeName(typeid:string):string; //根據書類型ID獲得類型名
    function GetBookTypeID(typename:string):string; // 根據書類型名獲得類型ID
    function GetStockBookNum(bookid:string):integer;//獲得庫存中某書總數
    function DeleteBook(bookid:string):boolean;     //刪除圖書數為0的所有圖書信息
    function ModifyPassword(username,newpass:string):boolean;    //修改用戶密碼
    function CheckUserPassword(username,password:string):boolean;//檢測密碼正確性
    function CheckUserName(username:string):boolean;             //檢測用戶名
    function GetUserPurviewMenu(username:string):boolean;        //獲得用戶權限可使用菜單
    function GetMenuName(menuid:string):string;                  //通過菜單ID獲得菜單名
    function GetReaderEducationName(educationid:string):string;  //通過學歷ID獲得學歷名
    function GetReaderEducationID(educationname:string):string;  //通過學歷ID獲得學歷名
    function GetReaderTypeName(typeid:string):string;            //通過讀者類型ID獲得類型名
    function GetReaderTypeID(typeNAME:string):string;            //通過讀者類型名獲得類型ID
    function GetReaderLendBookNum(readercardid:string):integer;  //通過讀者卡號獲得讀者所借書數(未歸還書數)
    function GetReaderLendBookCount(readercardid:string):integer;//通過卡號返回此卡借書總數
    function CheckReaderLendBookName(readercardid,bookid:string):boolean;//檢查未歸還書中有無此書
    function SaveUserLongin(username:string;longin:boolean):boolean;     //登陸日志
    function GetAllBookNum:integer; // 獲得庫中圖書總數
  end;

var
  DM: TDM;

implementation

uses MainU,ShareU;
{$R *.dfm}


//保存登陸日志
function TDM.SaveUserLongin(username:string;longin:boolean):boolean;
var
  Query:TADOQuery;
begin
     Query:=TADOQuery.Create(self);
     Query.Connection:=ADOConnection1;
     try
     dm.ADOConnection1.BeginTrans;
     if longin then
     begin
       Query.SQL.Text:='insert into User_LoginLog (username,uptime,downtime)'+
                     'values (:username,:uptime,:downtime)';
       Query.Parameters.ParamByName('username').Value:=username;
       Query.Parameters.ParamByName('uptime').Value:=CurUserLonginTime;
       Query.Parameters.ParamByName('downtime').Value:=CurUserLonginTime;
     end
     else
     begin
       Query.SQL.Text:='update User_LoginLog set downtime=:downtime where'+
                       ' username=:username and uptime=:uptime';
       Query.Parameters.ParamByName('downtime').Value:=now;
       Query.Parameters.ParamByName('username').Value:=username;
       Query.Parameters.ParamByName('uptime').Value:=CurUserLonginTime;
     end;
     Query.ExecSQL;
     dm.ADOConnection1.CommitTrans;
     result:=true;
     except
       dm.ADOConnection1.RollbackTrans;
       result:=false;
     end;
     
     Query.Close;
     Query.Free;
end;

//檢查未歸還書中有無此書
function TDM.CheckReaderLendBookName(readercardid,bookid:string):boolean;
var
  Query:TADOQuery;
begin
   Query:=TADOQuery.Create(self);
   Query.Connection:=dm.ADOConnection1;
   Query.SQL.Text:='select bookid from lend_book where readercardid=:id '+
                   'and bookid=:bookid and state=1';
   Query.Parameters.ParamByName('id').Value:=readercardid;
   Query.Parameters.ParamByName('bookid').Value:=bookid;
   Query.Open;
   if not (query.RecordCount >0) then
       Result:=false  //沒
   else
       result:=true;  //有
   Query.Close;
   Query.Free;
end;

//通過卡號返回此卡借書總數
function TDM.GetReaderLendBookCount(readercardid:string):integer;
var
  Query:TADOQuery;
begin
   Query:=TADOQuery.Create(self);
   Query.Connection:=dm.ADOConnection1;
   Query.SQL.Text:='select lendbook from reader_type where readertypeid in '+
                   ' (select readertypeid from reader_info where '+
                   ' readercardid=:readercardid)';
   Query.Parameters.ParamByName('readercardid').Value:=readercardid;
   Query.Open;
   Result:=query.FieldValues['lendbook'];
   Query.Close;
   Query.Free;
end;

//通過讀者卡號獲得讀者所借書數(未歸還書數)
function TDM.GetReaderLendBookNum(readercardid:string):integer;
var
  Query:TADOQuery;
begin
   Query:=TADOQuery.Create(self);
   Query.Connection:=dm.ADOConnection1;
   Query.SQL.Text:='select readercardid from lend_book where readercardid=:'+
                   'readercardid and state=:state';
   Query.Parameters.ParamByName('readercardid').Value:=readercardid;
   Query.Parameters.ParamByName('state').Value:=1;
   Query.Open;
   Result:=Query.RecordCount;
   Query.Close;
   Query.Free;
end;

//通過學歷ID獲得學歷名
function TDM.GetReaderEducationID(educationname:string):string;
var
  Query:TADOQuery;
begin
    Query:=TADOQuery.Create(self);
    Query.Connection:=ADOConnection1;
    Query.SQL.Text:='select educationid from reader_education where '+
                           ' educationname=:name';
    Query.Parameters.ParamByName('name').Value:=educationname;
    Query.Open;
    result:=trim(Query.FieldValues['educationid']);
    Query.Close;
    Query.Free;
end;

//通過類型ID獲得類型名
function TDM.GetReaderTypeName(typeid:string):string;
var
  Query:TADOQuery;
begin
    Query:=TADOQuery.Create(self);
    Query.Connection:=ADOConnection1;
    Query.SQL.Text:='select typename from reader_type where '+
                           ' readertypeid=:id';
    Query.Parameters.ParamByName('id').Value:=typeid;
    Query.Open;
    result:=trim(Query.FieldValues['typename']);
    Query.Close;
    Query.Free;
end;

//通過類型ID獲得類型名
function TDM.GetReaderTypeID(typename:string):string;
var
  Query:TADOQuery;
begin
    Query:=TADOQuery.Create(self);
    Query.Connection:=ADOConnection1;
    Query.SQL.Text:='select readertypeid from reader_type where '+
                           ' typename=:name';
    Query.Parameters.ParamByName('name').Value:=typename;
    Query.Open;
    result:=trim(Query.FieldValues['readertypeid']);
    Query.Close;
    Query.Free;
end;

//通過學歷ID獲得學歷名
function TDM.GetReaderEducationName(educationid:string):string;
var
  Query:TADOQuery;
begin
    Query:=TADOQuery.Create(self);
    Query.Connection:=ADOConnection1;
    Query.SQL.Text:='select educationname from reader_education where '+
                           ' educationid=:id';
    Query.Parameters.ParamByName('id').Value:=educationid;
    Query.Open;
    result:=trim(Query.FieldValues['educationname']);
    Query.Close;
    Query.Free;
end;

//通過菜單ID獲得菜單名
function TDM.GetMenuName(menuid:string):string;
var
  Query:TADOQuery;
begin
    Query:=TADOQuery.Create(self);
    Query.Connection:=ADOConnection1;
    Query.SQL.Text:='select menuname from menu_info where menuid=:id';
    Query.Parameters.ParamByName('id').Value:=menuid;
    Query.Open;
    result:=trim(Query.FieldValues['menuname']);
    Query.Close;
    Query.Free;
end;

//獲得用戶權限可使用菜單
function TDM.GetUserPurviewMenu(username:string):boolean;
var
  Query:TADOQuery;
  tempmenuname:string;
begin
    Query:=TADOQuery.Create(self);
    Query.Connection:=ADOConnection1;
    Query.SQL.Text:='select menuid from user_purview where username=:name';
    Query.Parameters.ParamByName('name').Value:=username;
    Query.Open;
    Query.First;
    while not Query.Eof do
    begin
        tempmenuname:=GetMenuName(Query.FieldByName('menuid').AsString);
        EnabledMenu(tempmenuname);
        Query.Next;
    end;
    result:=true;
    Query.Close;
    Query.Free;
end;

//檢測用戶名
function TDM.CheckUserName(username:string):boolean;
var
  Query:TADOQuery;
begin
    Query:=TADOQuery.Create(self);
    Query.Connection:=ADOConnection1;

    Query.SQL.Text:='select username from user_info where username=:name';
    Query.Parameters.ParamByName('name').Value:=username;
    Query.Open;
    if query.RecordCount=1 then
      result:=true
    else
      result:=false;
  Query.Close;
  Query.Free;
end;

//檢測密碼正確性
function TDM.CheckUserPassword(username,password:string):boolean;
var
  Query:TADOQuery;
begin
    Query:=TADOQuery.Create(self);
    Query.Connection:=ADOConnection1;

    Query.SQL.Text:='select userpassword from user_info where username=:name';
    Query.Parameters.ParamByName('name').Value:=username;
    Query.Open;
    if trim(Query.FieldByName('userpassword').Value)=password then
      result:=true
    else
      result:=false;
  Query.Close;
  Query.Free;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久久久免费| 亚洲欧美日韩综合aⅴ视频| 久久精品亚洲一区二区三区浴池| 欧美一区二区三区喷汁尤物| 国产欧美视频一区二区| 一区二区三区四区乱视频| 亚洲第一会所有码转帖| 国产一区二区成人久久免费影院 | 国产91精品一区二区| 色网综合在线观看| 精品国产91九色蝌蚪| 亚洲人成7777| 福利一区福利二区| 欧美精品乱码久久久久久| 精品久久久久久久一区二区蜜臀| 国产精品美女www爽爽爽| 亚洲乱码国产乱码精品精可以看| 九色|91porny| 777a∨成人精品桃花网| 中文天堂在线一区| 另类的小说在线视频另类成人小视频在线| 成人性生交大片免费| 91精品国产福利| 综合久久久久久久| 高清在线观看日韩| 日韩美女一区二区三区四区| 亚洲欧美国产77777| 韩国女主播一区二区三区| 91行情网站电视在线观看高清版| 日韩网站在线看片你懂的| 亚洲欧洲日产国产综合网| 美脚の诱脚舐め脚责91| 91成人网在线| 国产精品二三区| 激情小说亚洲一区| 日韩一区二区三区电影在线观看 | 成人午夜视频网站| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 国产精品一区一区三区| 91精品视频网| 三级久久三级久久久| 日本高清不卡一区| 亚洲免费伊人电影| 色诱亚洲精品久久久久久| 椎名由奈av一区二区三区| 国产精品一区二区三区四区 | 成人福利在线看| 精品欧美一区二区在线观看| 亚洲香蕉伊在人在线观| a4yy欧美一区二区三区| 亚洲天堂免费在线观看视频| 日本国产一区二区| 亚洲成人三级小说| 91精品国产免费久久综合| 日韩电影免费在线看| 日韩精品一区二区三区视频播放 | 蜜臀av性久久久久蜜臀av麻豆| 欧美日韩视频在线第一区 | 欧美日韩中文精品| 中文字幕一区在线观看| 91黄视频在线| 丝袜美腿亚洲综合| 精品免费视频一区二区| 国产一区二区影院| 中文字幕一区二区5566日韩| 91麻豆swag| 午夜精品久久久久久久久 | 亚洲国产另类精品专区| 欧美人成免费网站| 狠狠狠色丁香婷婷综合激情 | 欧美一区二区三区在| 精久久久久久久久久久| 国产片一区二区三区| 国产一区二区三区最好精华液| 日本一区二区三区四区 | 韩国av一区二区三区四区| 26uuu精品一区二区三区四区在线| 黄页视频在线91| 亚洲欧美在线aaa| 欧美一区二区三区在线| 国产91在线观看| 亚洲国产成人av网| 久久久综合网站| 日本久久一区二区三区| 国产精品丝袜黑色高跟| 91免费在线视频观看| 亚洲与欧洲av电影| 欧美精品一区二区久久久| av资源网一区| 久久国产三级精品| 亚洲婷婷综合色高清在线| 欧美一区2区视频在线观看| www.欧美.com| 蜜臀av在线播放一区二区三区| 国产网红主播福利一区二区| 欧美久久久久久蜜桃| 成人久久18免费网站麻豆| 视频在线观看一区| 最新高清无码专区| 欧美成人三级电影在线| 色av综合在线| 成人美女视频在线看| 精品在线一区二区| 一区二区三区四区视频精品免费| 国产色产综合产在线视频| 6080亚洲精品一区二区| av成人老司机| 国产盗摄一区二区| 午夜电影久久久| 国产色爱av资源综合区| 欧美一区二区成人| 欧美精品久久久久久久多人混战| 99国产欧美另类久久久精品| 国产成人在线网站| 黄页网站大全一区二区| 麻豆精品久久久| 日本午夜一本久久久综合| 亚洲综合色区另类av| 国产精品乱码妇女bbbb| 欧美激情艳妇裸体舞| www国产成人免费观看视频 深夜成人网| 在线国产亚洲欧美| 日本久久一区二区三区| 91在线视频官网| av在线综合网| 国产在线播放一区| 午夜私人影院久久久久| 亚洲欧洲av一区二区三区久久| 久久久久久久久久久黄色| 欧美成人a视频| 精品欧美一区二区久久| 久久综合资源网| 国产丝袜美腿一区二区三区| 欧美精品一区二区三区久久久 | 日本不卡123| 午夜精品久久久久| 日韩中文字幕一区二区三区| 亚洲18色成人| 蜜臀久久久久久久| 久久国产精品99久久久久久老狼| 蜜臀av一区二区在线免费观看| 麻豆精品精品国产自在97香蕉| 久久爱www久久做| 国产精品一区二区在线播放| av不卡在线观看| 91黄视频在线观看| 91精品国产综合久久久蜜臀粉嫩 | 亚洲国产色一区| 激情都市一区二区| 丰满亚洲少妇av| 91美女片黄在线观看| 欧美视频中文字幕| 欧美一区二区三区免费视频 | 91精品国产全国免费观看| 欧美精品一区二区三区蜜桃视频| 精品国产乱码久久久久久久| 国产精品你懂的| 亚洲伊人伊色伊影伊综合网| 蜜桃传媒麻豆第一区在线观看| 韩国一区二区在线观看| 99久久免费视频.com| 欧美在线高清视频| 91精品久久久久久久91蜜桃| 精品成人a区在线观看| 久久精品人人做人人爽人人| 亚洲欧美色综合| 日本不卡的三区四区五区| 成人精品鲁一区一区二区| 欧美在线制服丝袜| 欧美电视剧在线看免费| 一区二区三区四区国产精品| 粉嫩久久99精品久久久久久夜 | 久久婷婷国产综合国色天香| 亚洲一区二三区| 99r精品视频| 国产亚洲精品7777| 激情亚洲综合在线| 欧美大片拔萝卜| 亚洲1区2区3区4区| 在线视频国产一区| 亚洲免费在线看| 99亚偷拍自图区亚洲| 国产欧美一区二区三区鸳鸯浴 | 强制捆绑调教一区二区| 欧美在线观看18| 亚洲一区在线电影| 色av综合在线| 亚洲一区在线观看网站| 91福利视频在线| 亚洲一区av在线| 在线这里只有精品| 亚洲欧美日韩中文字幕一区二区三区 | 视频一区二区国产| 欧美三级一区二区| 亚洲尤物在线视频观看| 欧洲视频一区二区| 亚洲午夜精品一区二区三区他趣| 91蝌蚪porny| 亚洲一区二区在线观看视频| 欧美亚洲免费在线一区|