请问从数据库从查询符合日期、时间条件的记录的SQL语句应该怎么写。(20分)

  • 主题发起人 主题发起人 crazyboys
  • 开始时间 开始时间
C

crazyboys

Unregistered / Unconfirmed
GUEST, unregistred user!
var
sSelect: string;
QDateTime: TDateTime;
begin
// QDateTime:=StrToDateTime('2002-12-14 8:00:00');
QDateTime:=Now;
sSelect:='Select * From main_table Where RDate=''' + DateTimeToStr(QDateTime) + '''';
// ShowMessage(sSelect);
 
把它转换成字符串再比较。
 
sSelect:='Select * From main_table Where RDate=#' + DateTimeToStr(QDateTime) + '#';

或者 {}
看你用的什么库
 
如果是SQL SERVER :
可以用sSelect:='Select * From main_table Where RDate=''' + FormatDateTime("yyyy-mm-dd", QDateTime) + '''';
如果要比较分秒,可以把Format的参数替换一下。也可以用参数形式,比较简单.

参数: 'Select * From main_table Where RDate=:a'; //a就是时间参数
...param[a].value := QDateTime;就可以了

如果是Access数据库,就要把 ' 替换成 #。

如果还不懂,可以把问题发到我email来! redleilei@sina.com
 
faint 最简单的方法
'select * from main_table where to_char(Rdata,'YYYY-MM-DD')=:a'
这样外边的数据都可以用string 就行了啊!
 
我用的ACCESS数据库,字段为时间日期型,查询语句写成
sSelect:='Select * From main_table Where RDate like ''2002-12-14 9:00:00''';
就可以。
sSelect:='Select * From main_table Where RDate = ''2002-12-14 9:00:00''';
就出错。
我也试过把' 换成 #39但还是不行。
别人告诉我:若为Access数据库。'2002-12-14 8:00:00'可以是string的变量。
 
多人接受答案了。
 

Similar threads

S
回复
0
查看
3K
SUNSTONE的Delphi笔记
S
S
回复
0
查看
2K
SUNSTONE的Delphi笔记
S
S
回复
0
查看
928
SUNSTONE的Delphi笔记
S
后退
顶部