关于SQL模糊查询日期时间的方法

SQL语句如下:selectPunchtimefromdbo.attendpunch,dbo.employeewhereattendpunch.empno=employe... SQL语句如下:
select Punchtime from dbo.attendpunch,dbo.employee where attendpunch.empno=employee.empno
and employee.empno='12020' and attendpunch.Punchtime like'%2007-05-17%' order by attendpunch.Punchtime

需要模糊查询表中所有关于2007-05-17这一天的纪录,可每次运行出来的都是空的,怀疑是数据类型不匹配导致查询不到,请教高手如何解决这个问题?
展开
 我来答
大野瘦子
高粉答主

2018-12-07 · 繁杂信息太多,你要学会辨别
知道小有建树答主
回答量:1227
采纳率:100%
帮助的人:34.6万
展开全部

有以下三种方法:

1、Convert转成String,在用Like查询

select * from table1   where convert(varchar,yourtime,120) like   '2017-06-30%'  

2、Between

select * from table1 where yourtime between '2017-06-30 0:00:00' and '2017-06-30 24:59:59'";

3、datediff()函数

select * from table1   where datediff(day,yourtime,'2017-06-30')=0 

扩展资料:

滚与上述日期格式的like模糊查询的注意事项

1、select * from T where sendTime like '%2007_12_%'    可以查询2007年12月的所有记录

如果like条件改为'%2007-12-%' ,'%2007_12_3%' ,或'%2007_12_30%' 都查不出数据。

2、select * from T where sendTime like '%12_30%'    可以查询12月30日的所有记录

如果like条件改为'%07_12_30%'  也查不出数据。

新模式行业
2018-12-30 · TA获得超过1.5万个赞
知道答主
回答量:37
采纳率:100%
帮助的人:1.3万
展开全部

1、Convert转成String,在用Like查询。

select * from table1   where convert(varchar,yourtime,120) like   '2017-06-30%'  

2、Between

select * from table1 where yourtime between '2017-06-30 0:00:00' and '2017-06-30 24:59:59'";

3、datediff()函数

select * from table1   where datediff(day,yourtime,'2017-06-30')=0 

扩展资料

表达式DateDiff(timeinterval,date1,date2 [, firstdayofweek [, firstweekofyear]])

允许数据类型: timeinterval 表示相隔时间的类型,代码为:

年份 yy、yyyy 季度 qq、q

月份 mm、m

每年的某一日 dy、y

日期 dd、d

星期 wk、ww

工作日 dw

小时 hh

分钟 mi、n

秒 ss、s

毫秒 ms

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
兔丞飞
高粉答主

2018-12-17 · 专注娱乐 专注娱乐 专注娱乐
兔丞飞
采纳数:25 获赞数:19893

向TA提问 私信TA
展开全部

1、Convert转成String,在用Like查询

select * from table1   where convert(varchar,yourtime,120) like   '2017-06-30%'  

2、Between

select * from table1 where yourtime between '2017-06-30 0:00:00' and '2017-06-30 24:59:59'";

3、datediff()函数

select * from table1   where datediff(day,yourtime,'2017-06-30')=0 

扩展资料

表达式DateDiff(timeinterval,date1,date2 [, firstdayofweek [, firstweekofyear]])

允许数据类型: timeinterval 表示相隔时间的类型,代码为:

年份 yy、yyyy 季度 qq、q

月份 mm、m

每年的某一日 dy、y

日期 dd、d

星期 wk、ww

工作日 dw

小时 hh

分钟 mi、n

秒 ss、s

毫秒 ms

参考资料:百度百科 DateDiff()

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
玩着还v
2018-12-31 · TA获得超过2.6万个赞
知道答主
回答量:57
采纳率:0%
帮助的人:2.1万
展开全部

1、Convert转成String,在用Like查询。

select * from table1   where convert(varchar,yourtime,120) like   '2017-06-30%'  

2、Between

select * from table1 where yourtime between '2017-06-30 0:00:00' and '2017-06-30 24:59:59'";

3、datediff()函数

select * from table1   where datediff(day,yourtime,'2017-06-30')=0 

扩展资料

表达式DateDiff(timeinterval,date1,date2 [, firstdayofweek [, firstweekofyear]])

允许数据类型: timeinterval 表示相隔时间的类型,代码为:

年份 yy、yyyy 季度 qq、q

月份 mm、m

每年的某一日 dy、y

日期 dd、d

星期 wk、ww

工作日 dw

小时 hh

分钟 mi、n

秒 ss、s

毫秒 ms

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
du瓶邪
推荐于2017-10-01 · TA获得超过2.4万个赞
知道大有可为答主
回答量:1.7万
采纳率:100%
帮助的人:2956万
展开全部
模糊查询有以下三种方法:
1.Convert转成String,在用Like查询。
select * from table1 where convert(varchar,date,120) like '2006-04-01%'

2.Between
select * from table1 where time between '2006-4-1 0:00:00' and '2006-4-1 24:59:59'";

3 datediff()函数
select * from table1 where datediff(day,time,'2006-4-1')=0

第一种方法应该适用与任何数据类型;
第二种方法适用String外的类型;
第三种方法则是为date类型定制的比较实用快捷的方法。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(6)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式