如何用SQL查询一个时间段内的特定时间数据?

数据库有一列tm格式是8位datatime,存年月日时分秒。现在我想查一个月内每天12点整的数据,命令如何写?... 数据库有一列tm格式是8位datatime,存年月日时分秒。
现在我想查一个月内每天12点整的数据,命令如何写?
展开
 我来答
alex_hy
推荐于2021-01-02 · TA获得超过1.3万个赞
知道大有可为答主
回答量:2601
采纳率:100%
帮助的人:980万
展开全部
datetime型的精度是微秒级的,楼上两位只写到秒,还是有出错的可能

将一个datetime取整(取到00:00)有3种方法:

convert(smalldatetime,convert(varchar,日期,112),112)

cast(cast(日期 as int) as smalldatetime)

dateadd(dd,datediff(dd,'2010-1-1',日期),'2010-1-1')

根据你的需求,用方法1,条件写成
where tm>='2010-3-1' and tm<'2010-4-1'
and tm=dateadd(hh,12,convert(smalldatetime,convert(varchar,tm,112),112))
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
dr_zxp
推荐于2018-04-09 · TA获得超过861个赞
知道小有建树答主
回答量:765
采纳率:100%
帮助的人:854万
展开全部
sql server
SELECT * FROM 表名 WHERE datepart(hour,tm)=12 and datepart(minute,tm)=0 and datepart(second,tm)=0 and datediff(month,tm,getdate())<1

access:用now()代替getdate()
oracle:用sysdate代替getdate()
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
wannalcxl
2010-07-31 · TA获得超过260个赞
知道小有建树答主
回答量:640
采纳率:0%
帮助的人:623万
展开全部
SELECT * FROM 表名 WHERE Hour(tm)=12 and Minute(tm)=0 and Second(tm)=0
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式