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

2024-12-01 10:35:47
推荐回答(5个)
回答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 

扩展资料:

滚与上述日期格式的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%'  也查不出数据。

回答2:

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

回答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

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

回答4:

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

回答5:

模糊查询有以下三种方法:
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类型定制的比较实用快捷的方法。