1. 程式人生 > 資料庫 >Delphi程式設計SQL語句中引號(')、quotedstr()、('')、format()在SQL語句中的用法

Delphi程式設計SQL語句中引號(')、quotedstr()、('')、format()在SQL語句中的用法

總結一下SQL語句中引號(')、quotedstr()、('')、format()在SQL語句中的用法以
及SQL語句中日期格式的表示(#)、('')
在Delphi中進行字元變數連線相加時單引號用('''),雙引號用('''')表示
首先定義變數
var
AnInt:integer=123;//為了方便在此都給它們賦初值。雖然可能在引賦初值在某些情況下不對
AnIntStr:string='456';
AStr:string='abc';
AFieldName: string='字元型編號';
ATableName: string='YourTable';
ADate:Tdatetime=now;
Adoquery1:tadoquery;

1,Delphi語句
adoquery1.sql.text:=
'select 字元型編號 from YourTable where 字元型編號='abc' and 整型編號=123';
等價於
adoquery1.sql.text:=
'select '+AFieldName+' from '+ATableName+' where '+AFieldName
+'='''+AStr+''' and 整型編號='+AnIntStr;
也等價於
adoquery1.sql.text:=
'select '+AFieldName+' from '+ATableName+' where '+AFieldName
+'='+QuotedStr(AStr)+' and 整型編號='+Inttostr(AnInt);

傳到資料庫伺服器為:
select 字元型編號 from YourTable where 字元型編號='abc' and 整型編號=123

2,Delphi語句中日期表示
對於access資料庫:
adoquery1.sql.text:=
'select 字元型編號 from YourTable where 日期型欄位=#2003-12-01#';
等價於:
adoquery1.sql.text:=
'select 字元型編號 from YourTable where 日期型欄位=#'+FormatDateTime('yyyy-MM-dd',now)+'#';
傳到伺服器為:
select 字元型編號 from YourTable where 日期型欄位=#2003-12-01#

對於MSSQL資料庫:
adoquery1.sql.text:=
'select 字元型編號 from YourTable where 日期型欄位='2003-12-01'';
等價於:
adoquery1.sql.text:=
'select 字元型編號 from YourTable where 日期型欄位='''+FormatDateTime('yyyy-MM-dd',now)+'''';
也等價於:
等價於:
adoquery1.sql.text:=
'select 字元型編號 from YourTable where 日期型欄位='+QuotedStr(FormatDateTime('yyyy-MM-dd',now));

傳到伺服器為:
select 字元型編號 from YourTable where 日期型欄位='2003-12-01'

日期欄位還可以這樣表示
Delphi語句
adoquery1.sql.text:=
'select 字元型編號 from YourTable where 日期型欄位>='+QuotedStr(FormatDateTime('yyyy-MM-dd',now))
+' and 日期型欄位<='+QuotedStr(FormatDateTime('yyyy-MM-dd',now+1));//明天
等價於
adoquery1.sql.text:=
'select 字元型編號 from YourTable where 日期型欄位 between '+QuotedStr(FormatDateTime('yyyy-MM-dd',now))
+' and '+QuotedStr(FormatDateTime('yyyy-MM-dd',now+1));




如果用
adoquery1.sql.add();
形式又如何操作?請用Insert語句示例

adoquery1.sql.add(' insert into '+AtableName);
adoquery1.sql.add(' ( '+AFieldName+')');
adoquery1.sql.add(' values( '+quotedstr(AStr)+')');