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

发布网友

我来回答

7个回答

热心网友

有以下三种方法:

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、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

热心网友

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

热心网友

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

热心网友

select Punchtime from dbo.attendpunch,dbo.employee where attendpunch.empno=employee.empno
and employee.empno='12020' and attendpunch.Punchtime between '2007-05-17 00:00:00' and '2007-05-17 23:59:59' order by attendpunch.Punchtime

热心网友

日期不是字符串,其实是一个double类型的数字,这样找肯定不行的了,要找这一天的,就找大于今天0点的,小于下一天0点的,就行了么
或者找找求日期的什么函数,光比较日期

热心网友

要返回正确的记录,你需要适用日期和时间范围。有不止一种途径可以做到这一点。例如,下面的这个SELECT 语句将能返回正确的记录:

SELECT * FROM weblog

WHERE entrydate>=”12/25/2000” AND entrydate<”12/26/2000”

这个语句可以完成任务,因为它选取的是表中的日期和时间大于等于12/25/2000 12:00:00:000AM并小于12/26/2000 12:00:00:000AM的记录。换句话说,它将正确地返回2000年圣诞节这一天输入的每一条记录。

另一种方法是,你可以使用LIKE来返回正确的记录。通过在日期表达式中包含通配符“%”,你可以匹配一个特定日期的所有时间。这里有一个例子:

SELECT * FROM weblog WHERE entrydate LIKE ‘Dec 25 2000%’

这个语句可以匹配正确的记录。因为通配符“%”代表了任何时间。

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com