① 在sql中比较时间的大小怎么做在线等
您好:
还以为有人会抢答。
直接大于号小于号就可以比较了。
时间越晚,比较的时候值越大。
SELECT*FROM表WHERE时间字段>'2017-01-01'
以上是一个简单的例子,请参考。
② SQL 时间比较
有这么一个古老的传说:
相传,在远古时期,猪头设计者们定义日期类型的时候,一共制定了两套:Date 和 Datetime 类型,
Date是日期的,如:2010-3-15
Datetime日期及时间的,如:2010-3-15 12:01:56:469
假设你要比较的两个时间都是Datetime类型数据,它们不相等的可能性也许是99.99%,因为不仅日子要一样,而且小时、分钟、秒、微秒都要相等,那才算是一致。
假设交易日期这个数据是今天上午产生的,开始日期是今天下午生成的,那么,肯定不相等了。
所以你要让同一天(不管几点钟)的相关联,那就用个函数吧,办法太多了:
①:将Datetime转换为Data再比较,where条件:
convert(date,a.交易记账日期) >= convert(date,b.开始日期)
例如:convert(date, 2010-3-15 19:25:30) 就会返回date型的 2010-3-15 00:00:00,小时分钟什么的全是0了,所以同一天的就相等了
②:将它们按你要求的格式转换为字符串后再比较,where条件:
convert(varchar,a.交易记账日期,102) >= convert(varchar,b.开始日期,102)
例如:convert(varchar, 2010-3-15 19:25:30, 102) 就会返回字符型的2010.3.15,小时分钟什么的全甩掉了
=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*=*
请根据这个传说对号入座,希望有所提醒,如果不是这个原因,咱们再研究~
③ sql时间对比问题
where dateadd(day,天数,createtime)<getdate()
where dateadd(month,月数,createtime)<getdate()
④ sql数据库时间如何比较
SELECT DATEDIFF(DAY, (SELECT table.dtime FROM table WHERE ID=1 )
,GETDATE())
//
(SELECT table.dtime FROM table WHERE ID=1 )
是你要从数据库中提取的时间,重新自定义一下
GETDATE()是今天的日期
总的就是表示从数据库里提取的时间到今天的差距
如果是想比较数据库和数据库里的时间,就按照上面的方法再写一次
⑤ sql时间如何比较
这里的4年应该用月份来计算比较合理,超过4年就是使用月份大于48个月
不超过4年就是小于等于48个月。
使用超过4年的
select * from 表名
where datediff(month,[开始使用日期],getdate())>48
使用不到4年的
select * from 表名
where datediff(month,[开始使用日期],getdate())<=48
⑥ SQL里时间怎么比较
1\如果是指90天
select *
from table
where datediff(day,time,getdate())<=90
或者
select *
from table
where time>=dateadd(day,-90,getdate())
2\如果是3月
select *
from table
where time>=dateadd(month,-3,getdate())
3\如果是当前月往前推两个自然月的1号算起
select *
from table
where time>=Dateadd(mm,datediff(mm,0,getdate())-2,0)
⑦ sql中,怎么对时间进行比较
这个估计是日历时间,一般就是从January 1, 1970, UTC午夜开始到现在所经过的秒数
你可以用DATEADD函数在秒上加上这个数来把它转化为它对应的datetime类型所表示的时间
比如:
select DATEADD(ss, 1257322946, '1970-1-1 00:00:00')
返回
-----------------------
2009-11-04 08:22:26.000
(1 row(s) affected)
⑧ 在sql两个日期型如何比较早晚
思路:
sql@kokooa>select * from test038;
A B C
-------------- -------------- --------------
18-9月 -09 09-10月-09 09-8月 -08
sql@kokooa> select f from(
2 select a,b,c,(case when d-c>0 then d else c end) as f from(
3 select a,b,c,(case when a-b>0 then a else b end) as d from test038));
F
--------------
09-10月-09
这样就求出最大日期了也就是最迟日期
⑨ Sql字符串与时间比较问题
oracle比较字符串是根据ascii码来的,第一个字母的ascii大小比较如果相等再比较下一个,类推。
字符串和数字进行操作是会报异常的,因为类型不一样不能进行比较。
oracle在执行sql的时候有些时候会自动转换,比如:
select
*
from
chan_customer
cc
where
cc.customer_id
=
'1';
即使customer_id是数字型的也可以查出来,但是oracle有区分字符和数字
就是通过加不加单引号来区分。
⑩ sql 时间比较
--记录在表是字符?
select * from table order by left(日期,charindex('月',日期)-1)*1,right(日期,charindex('月',reverse(日期))-1)*1