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

2021-05-23 21:12:31 字數 3005 閱讀 4592

2010-04

-13文章分類:資料庫

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 查詢本日本周本月 時間 問題

sql 查詢本週本月問題 查詢今日資訊 select from 表名 where datediff day,時間字段,getdate 0 其中day可以換成其他時間函式如month等 求相差天數 select datediff day,2004 01 01 getdate 1.乙個月第一天的 sel...

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