免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 5827 | 回复: 15
打印 上一主题 下一主题

关于用语句求出日期差值的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-08-15 16:39 |只看该作者 |倒序浏览
各位高手:
    我想在表ehome_SG_04test中的两个字段InstallDate和FirstReceptTime中求出差值为小于15天的记录
语句如下:
select  InstallDate, FirstReceptTime from ehome_SG_04test where

convert(varchar,InstallDate)-convert(varchar,FirstReceptTime)<=15
报错如下:
Server 'JM_CCATS112', Line 1:
Invalid operator for datatype op: SUBTRACT type: VARCHAR.
应该如何修改呢?请指教,谢谢!
两个字段的格式为

InstallDate                                                                                               

-----------                                                                                               

2008-07-16 12:52:07                                                                                       

2008-07-18 17:28:02                                                                                       

2008-07-17 11:33:23                                                                                       

      
FirstReceptTime
---------------      
2008-07-22 17:52:14  
2008-07-26 16:02:40   
2008-07-18 12:40:12

论坛徽章:
0
2 [报告]
发表于 2008-08-16 00:01 |只看该作者

回复 #1 inhance 的帖子

字符串能减吗?正确应该是这样的:
datediff(dd,FirstReceptTime,InstallDate) <=15

论坛徽章:
0
3 [报告]
发表于 2008-08-19 10:17 |只看该作者
谢谢楼上的指导!
    我执行后,结果是这样的:

select InstallDate,FirstReceptTime from ehome_SG_04test
where datediff(dd,FirstReceptTime,InstallDate)<=15

Server Message:  Number  249, Severity  16
Server 'JM_CCATS112', Line 1:
Syntax error during implicit conversion of VARCHAR value '业务开通时间' to a DATETIME field.

这个是不是由于字段FirstReceptTime和InstallDate有中文标题有关呢?怎样可以忽略呢?

论坛徽章:
1
2017金鸡报晓
日期:2017-01-10 15:19:56
4 [报告]
发表于 2008-08-19 12:45 |只看该作者
InstallDate,FirstReceptTime 这个两个字段是什么类型的?

论坛徽章:
0
5 [报告]
发表于 2008-08-19 14:53 |只看该作者
都是varchar类型啊  Lengh=125

论坛徽章:
1
2017金鸡报晓
日期:2017-01-10 15:19:56
6 [报告]
发表于 2008-08-19 16:34 |只看该作者
你的server什么版本?我在12.53上试了是可以的

论坛徽章:
0
7 [报告]
发表于 2008-08-19 17:33 |只看该作者
12.5.4
跟这个有关系吗?

论坛徽章:
1
2017金鸡报晓
日期:2017-01-10 15:19:56
8 [报告]
发表于 2008-08-19 18:18 |只看该作者
select datediff(dd,InstallDate,FirstReceptTime) from ehome_SG_04test

论坛徽章:
0
9 [报告]
发表于 2008-08-19 21:25 |只看该作者
select datediff(dd,InstallDate,FirstReceptTime) from ehome_SG_04test

Server Message:  Number  249, Severity  16
Server 'JM_CCATS112', Line 1:
Syntax error during implicit conversion of VARCHAR value '申告时间' to a DATETIME field.

是不是都是跟这两个字段是字符有关啊?

论坛徽章:
1
2017金鸡报晓
日期:2017-01-10 15:19:56
10 [报告]
发表于 2008-08-20 08:19 |只看该作者
申告时间 是什么?没看到这个字段?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP