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

一个窗体上有两个TDateTimePicker和一个按钮,一个用来选取开始日期,一个用来选取结束日期,点击按钮就可以将一个表zy_inbase中indate字段的日期介于... 一个窗体上有两个TDateTimePicker和一个按钮,一个用来选取开始日期,一个用来选取结束日期,点击按钮就可以将一个表zy_inbase中indate字段的日期介于开始和结束日期的所有记录复制到另一个表zy_inbase_temp中。我这样写有什么问题吗,为什么通不过呢?

var
sdate,edate:Tdatetime;

begin
sdate:=DateTimePicker1.Date;
edate:=DateTimePicker1.Date;

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

ADOQuery1.ExecSQL;
end;
展开
 我来答
扰龙彤彤0HV48f
2013-11-13 · TA获得超过407个赞
知道答主
回答量:416
采纳率:0%
帮助的人:120万
展开全部
你那个 zy_inbase表里的indate是什么类型的?以及什么格式的,你可以看下是否一致,另外如果不一致的话得用FormatDateTime('yyyy/mm/dd', sdate)来转换一下
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
Milo_WuW
2013-11-13 · 超过30用户采纳过TA的回答
知道答主
回答量:87
采纳率:0%
帮助的人:66.9万
展开全部
你要分步调试下,有没有试试"insert into zy_inbase_temp select * from zy_inbase where indate between '''+sdate+''' and '''+edate+'" 这个字符串输出的是什么?
你要说出来在哪里不OK了,才能给你解决
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
a470198949
2013-11-13 · TA获得超过359个赞
知道小有建树答主
回答量:592
采纳率:59%
帮助的人:203万
展开全部
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;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式