delphi+sql,请教一条SQL语句的写法

2025-03-12 01:30:35
推荐回答(3个)
回答1:

你那个 zy_inbase表里的indate是什么类型的?以及什么格式的,你可以看下是否一致,另外如果不一致的话得用FormatDateTime('yyyy/mm/dd', sdate)来转换一下

回答2:

你要分步调试下,有没有试试"insert into zy_inbase_temp select * from zy_inbase where indate between '''+sdate+''' and '''+edate+'" 这个字符串输出的是什么?
你要说出来在哪里不OK了,才能给你解决

回答3:

ADOQuery1.Close;

ADOQuery1.SQL.Clear;
ADOQuery1.SQL.Add('delete from zy_inbase_temp ');
ADOQuery1.SQL.Add(' insert into zy_inbase_temp values( select * from zy_inbase where indate between '''+sdate+''' and '''+edate+''' '));

ADOQuery1.ExecSQL;

你去试一下行不?如果不行,在两个ADOQuery1.SQL.Add(....)之间加上这么一句:
ADOQuery1.SQL.Clear;