sql 查詢本日本周本月 時間 問題

2021-08-25 03:52:00 字數 2954 閱讀 7014

sql 查詢本週本月問題

---查詢今日資訊

select   *   from   表名 where   datediff(day,時間字段,getdate())=0

其中day可以換成其他時間函式如month等

---求相差天數  

select   datediff(day,'2004-01-01',getdate())      

--1.乙個月第一天的  

select   dateadd(mm,   datediff(mm,0,getdate()),   0)  

--2.本週的星期一  

select   dateadd(wk,   datediff(wk,0,getdate()),   0)  

select   dateadd(wk,datediff(wk,0,getdate()),6)  

--3.一年的第一天  

select   dateadd(yy,   datediff(yy,0,getdate()),   0)  

--4.季度的第一天  

select   dateadd(qq,   datediff(qq,0,getdate()),   0)  

--5.當天的半夜  

select   dateadd(dd,   datediff(dd,0,getdate()),   0)  

--6.上個月的最後一天  

select   dateadd(ms,-3,dateadd(mm,   datediff(mm,0,getdate()),   0))  

--7.去年的最後一天  

select   dateadd(ms,-3,dateadd(yy,   datediff(yy,0,getdate()),   0))  

--8.本月的最後一天  

select   dateadd(ms,-3,dateadd(mm,   datediff(m,0,getdate())+1,   0))  

--9.本年的最後一天  

select   dateadd(ms,-3,dateadd(yy,   datediff(yy,0,getdate())+1,   0))  

--10.本月的第乙個星期一  

select   dateadd(wk,  

datediff(wk,0,dateadd(dd,6-datepart(day,getdate()),getdate())),   0)

--查詢本週註冊人數  

select   count(*)   from   [user]  

where   datediff(week,create_day-1,getdate())=0  

--上週註冊人數  

select   count(*)   from   [user]  

where   datediff(week,create_day-1,getdate())=1  

--本月註冊人數  

select   count(*)   from   [user]  

where   datediff(month,create_day,getdate())=0  

--上月註冊人數  

select   count(*)   from   [user]  

where   datediff(month,create_day,getdate())=1  

--如果要效率,這樣寫查詢  

--查詢本週註冊人數  

select   count(*)   from   [user]  

where   create_day>=dateadd(day,2-datepart(weekday,getdate()),convert(varchar,getdate(),112))  

and   create_day=dateadd(day,-5-datepart(weekday,getdate()),convert(varchar,getdate(),112))  

and   create_day=dateadd(day,1-day(getdate()),convert(varchar,getdate(),112))  

and   create_day=dateadd(month,-1,dateadd(day,1-day(getdate()),convert(varchar,getdate(),112)))  

and   create_day

學習  

month(create_day)=month(getdate())本月  

month(create_day)=month(getdate())-1   上月

補充 查詢今日所有的

select * from feedback where (datediff(d,fedtime,getdate())=0) order by fedid desc

下面的可能好些,加了判斷是不是本年的,上面的本週,本月會把每年的都查出來

查詢本月的記錄

select * from tablename where datepart(mm, thedate) = datepart(mm, getdate()) and datepart(yy, thedate) = datepart(yy, getdate())

查詢本週的記錄

select * from tablename where datepart(wk, thedate) = datepart(wk, getdate()) and datepart(yy, thedate) = datepart(yy, getdate())

查詢本季的記錄

select * from tablename where datepart(qq, thedate) = datepart(qq, getdate()) and datepart(yy, thedate) = datepart(yy, getdate())

sql 查詢本日本周本月 時間 問題

2010 04 13文章分類 資料庫 sql 查詢本週本月問題 查詢今日資訊 select from 表名 where datediff day,時間字段,getdate 0 其中day可以換成其他時間函式如month等 求相差天數 select datediff day,2004 01 01 ge...

sql 查詢本週本月問題

sql 查詢本週本月問題 求相差天數 select datediff day,2004 01 01 getdate 1.乙個月第一天的 select dateadd mm,datediff mm,0,getdate 0 2.本週的星期一 select dateadd wk,datediff wk,0...

TP 時間查詢(當日 本週 本月 本年)

1 按照日期查詢類似於當日 本週 本月 本年的資料 獲取當日的資料 db table table wheretime times today select 獲取昨天的資料 db table table wheretime times yesterday select 獲取本週的資料 db table...