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

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这一天的纪录,可每次运行出来的都是空的,怀疑是数据类型不匹配导致查询不到,请教高手如何解决这个问题?

有以下三种方法:

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%'  也查不出数据。

温馨提示:答案为网友推荐,仅供参考
第1个回答  2018-12-30

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

本回答被网友采纳
第2个回答  2018-12-17

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()

本回答被网友采纳
第3个回答  2018-12-31

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

本回答被网友采纳
第4个回答  推荐于2017-10-01
模糊查询有以下三种方法:
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类型定制的比较实用快捷的方法。