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