为了账号安全,请及时绑定邮箱和手机立即绑定

sql 取最接近日期

sql 取最接近日期

ITMISS 2018-12-06 23:36:24
有这样一个需求, 2010-11-1日 土豆价格在价格信息表中有一个记录 id           name      price 1    土豆    9.0 需要查询:2009-11-1日 土豆价格 以计算环比值。 如果2009-11-1日没有土豆的价格信息,则取最接近日期的信息作为环比计算的值, 这个Sql 语句应该怎么实现?  
查看完整描述

8 回答

?
人到中年有点甜

TA贡献1895条经验 获得超7个赞

清海扬波的基础上进行一定的修改

楼主可以一试:

select top 1 price from tb where name="土豆" and  (NOT price IS NULL)  and (日期<= GETDATE()) 

查看完整回答
反对 回复 2019-01-07
?
慕村9548890

TA贡献1884条经验 获得超4个赞

select top 1 * from PriceTable where CreateTime<=‘2009-11-1 23:59:29’ order by createTime desc. 

查看完整回答
反对 回复 2019-01-07
?
MYYA

TA贡献1868条经验 获得超4个赞

24:00:00 是哪一天?
查看完整回答
反对 回复 2019-01-07
?
猛跑小猪

TA贡献1858条经验 获得超8个赞

没有24:00:00,我假设你的是DateTime格式,因为如果再Sql中用 '2009-11-1' 就会自动转换为日期 '2009-11-1 00:00:00' , 如果有数据的生成日期是'2009-11-01,8:00:00',那么就查不到。
查看完整回答
反对 回复 2019-01-07
?
慕莱坞森

TA贡献1810条经验 获得超4个赞

这样的答案是肯定不行的!!!
查看完整回答
反对 回复 2019-01-07
?
哈士奇WWW

TA贡献1799条经验 获得超6个赞

为什么呢?
查看完整回答
反对 回复 2019-01-07
?
蓝山帝景

TA贡献1843条经验 获得超7个赞

select top 1 price from tb order by 日期 desc

查看完整回答
反对 回复 2019-01-07
?
喵喔喔

TA贡献1735条经验 获得超5个赞

这个表有时间字段吗?如果没有,知道哪条是2010-11-1的数据的话,可以根据ID来获取最近的数据的

查看完整回答
反对 回复 2019-01-07
  • 8 回答
  • 0 关注
  • 579 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信