SQL语句怎么写?(40分)

  • 主题发起人 主题发起人 delphifaq
  • 开始时间 开始时间
D

delphifaq

Unregistered / Unconfirmed
GUEST, unregistred user!
数据库为INTRBASE ,
ASQL:='select * from xxx where FieldDateTime>='+ADate
其中 FieldDateTime为DateTime型的字段,Adate为用户输入DateTime型变量
但是,由于ADate不为字符,所以编译过不去,请问该如何写???
请不要写成ASQL:='select * from xxx where FieldDateTime>=:a',这样会给我
带来不方便,虽然可以完成任务,有无其他方法??/
另外:在INTRBASE中可否实现 select * Into TempTable from ATable where ....
 
ASQL:='select * from xxx where convert(datetime,convert(char(11),FieldDateTime,111))>='+''''+datetostr(DTPr_t.date)+'''';
试试看。
 
如果有回答,请也给我一份
 
正如wumeng兄所言,此问题关键在于SQL中可使用单引号来引用日期时间常量,
所剩的问题就是如何统一数据库中所用的日期时间和Delphi转化的日期时间格式了
 
interbase数据库:

'select * from xxx where FieldDateTime>='''+Formatdatetiem('mmm-d,yyyy', ADate)+ ''''
 
就是说:

f > "jan 1 , 1999"

就是这个格式
 
INTRBASE不懂,
一般两边加上 # 号就行, 如:

= #2000/6/6#


 
可以看看书!

应该把你的ADate变成标准日期,再用引号加进查询字符串!
 
多人接受答案了。
 

Similar threads

S
回复
0
查看
3K
SUNSTONE的Delphi笔记
S
S
回复
0
查看
2K
SUNSTONE的Delphi笔记
S
D
回复
0
查看
1K
DelphiTeacher的专栏
D
D
回复
0
查看
1K
DelphiTeacher的专栏
D
I
回复
0
查看
493
import
I
后退
顶部