SQL SERVER 在DELPHI中的日期比较处理

11 篇文章 0 订阅
3 篇文章 0 订阅

(1)     在sql server中用  DATA1>DATA2这样的方式查询日期存在较大的不确定性,因为日期数据常有小时,分钟,稍等数据,一般用datedif(day,data1,data2 )处理。

DATE2,大于DATE1,则相差的天数大于0,否则小于0,如果两者到日期都相等,则等于0

 

(2)      我在Delphi中用Tadoquery 进行查询时也出现错误 ,错误代码假定是这样的

str:='select * from aa where datediff(day ,日期,:rq1) <0';
qrylist.Close;
qrylist.SQL.Clear;
qrylist.SQL.Add(str);
qrylist.parameters.parambyname(rq1).value:=encodedate(2021,2,1);
qrylist.open
如果是2021年当天的数据,则不会显示 ,对此百思不得其解。

觖决方法
改为:

RQ1:=encodedate(2021,2,1);  //这里只是为了方便解释,才用的变量
str:='select * from aa where datediff(day ,日期,datediff(day,日期 ,''' + formatdatetime('c', rq1) + ''')<=0  ';
qrylist.Close;
qrylist.SQL.Clear;
qrylist.SQL.Add(str);
qrylist.open

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Delphi,可以使用多个函数来比较日期。其一些常用的函数包括: - CompareDateTime():用于比较两个时间是否相同。 - CompareDate():用于比较两个时间的日期部分是否相同。 - CompareTime():用于比较两个时间的时分秒部分是否相同。 - SameDateTime():用于比较两个时间是否完全相同,包括日期和时分秒。 - SameDate():用于比较两个时间的日期部分是否完全相同。 - SameTime():用于比较两个时间的时分秒部分是否完全相同。 在SQL Server,可以使用DATEDIFF函数来比较日期。例如,DATEDIFF函数可以计算两个日期之间的天数差距。通常使用DATEDIFF函数来处理日期比较而不是直接使用比较运算符(如>或<),因为日期数据通常包含小时、分钟、秒等信息。 在Delphi,可以使用格式化日期的函数来比较日期。例如,使用FormatDateTime函数将日期格式化为特定的字符串,并将其用于SQL查询的比较条件。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Delphi 时间的比较](https://blog.csdn.net/qq_43252758/article/details/98850053)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [SQL SERVERDELPHI日期比较处理](https://blog.csdn.net/lxy6904/article/details/114437856)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值