程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> Delphi >> sql查詢語句的拼接小技巧(高手勿噴),sql小技巧

sql查詢語句的拼接小技巧(高手勿噴),sql小技巧

編輯:Delphi

sql查詢語句的拼接小技巧(高手勿噴),sql小技巧


1. 基本的查詢語句後面加上 WHERE 1=1,便於增加查詢條件。

ASkStr := 'select * from Twork where 1=1 ';
if length(cxTEworkid.Text) <> 0 then 
begin
ASkStr := ASkStr + ' and GWORKID like ' +
quotedstr('%' + cxTEworkid.Text + '%')
end;

  

2. 多表查詢可以用一個字符串代替一個表。邏輯上更清晰。

  

WorkTable = 'select GWorkId from TWork where 1=1 ';
PayTable = 'select sum(GXMtotal) as SGXMtotal,GXMType from TPAY where GWorkId In ';
PayGroupBy = ' Group By GXMType ';
ASkStr := PayTable + ' ( ' + WorkTable + tmpwhere + ' ) ' + PayGroupBy;

 

3.自己定義一個連接函數,判斷數據庫初始化是否成功,便於控制。

  

function Tdm.InitDbOk: boolean;
begin
  result := true;
  if fileexists(DBFileName) then
  begin
    FDConn.DriverName := 'SQLite';
    FDConn.LoginPrompt := false;
    FDConn.Params.Clear;
    FDConn.Params.Values['Database'] := DBFileName;
    FDConn.Params.Values['DriverID'] := 'SQLite';
    FDConn.Params.Values['CharacterSet'] := 'utf8';
    try
      FDConn.Connected := true;
    except
      result := false;
    end;
  end
  else
    result := false;
end;

  

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved