sql 查詢本年、本月、本日記錄的語句,附SQL日期函數(shù)
查詢本日記錄
SELECT * FROM messages WHERE CONVERT(Nvarchar, CreateDate, 111) = CONVERT(Nvarchar, GETDATE(), 111) ORDER BY CreateDate DESC
SELECT * FROM 表 WHERE datediff(day,列名,getdate())=0
查詢本年
SELECT count(*) FROM messages WHERE datediff(year,CreateDate,getdate())=0
查詢本月
SELECT count(*) FROM messages WHERE datediff(month,CreateDate,getdate())=0
本周記錄
SELECT * FROM 表名 WHERE datediff(week,列名,getdate())=0
SQL 日期函數(shù)
1. 當前系統(tǒng)日期、時間
select getdate()
2. dateadd 在向指定日期加上一段時間的基礎(chǔ)上,返回新的 datetime 值
例如:向日期加上2天
select dateadd(day,2,'2004-10-15′) –返回:2004-10-17 00:00:00.000
3. datediff 返回跨兩個指定日期的日期和時間邊界數(shù)。
select datediff(day,'2004-09-01′,'2004-09-18′) –返回:17
4. datepart 返回代表指定日期的指定日期部分的整數(shù)。
SELECT DATEPART(month, '2004-10-15′) –返回 10
5. datename 返回代表指定日期的指定日期部分的字符串
SELECT datename(weekday, '2004-10-15′) –返回:星期五
6. day(), month(),year() –可以與datepart對照一下
select 當前日期=convert(varchar(10),getdate(),120)
,當前時間=convert(varchar(8),getdate(),114)
select datename(dw,'2004-10-15′)
select 本年第多少周=datename(week,'2004-10-15′)
,今天是周幾=datename(weekday,'2004-10-15′)
函數(shù) | 參數(shù)/功能 |
GetDate( ) | 返回系統(tǒng)目前的日期與時間 |
DateDiff (interval,date1,date2) | 以interval 指定的方式,返回date2 與date1兩個日期之間的差值 date2-date1 |
DateAdd (interval,number,date) | 以interval指定的方式,加上number之后的日期 |
DatePart (interval,date) | 返回日期date中,interval指定部分所對應(yīng)的整數(shù)值 |
DateName (interval,date) | 返回日期date中,interval指定部分所對應(yīng)的字符串名稱 |
參數(shù) interval的設(shè)定值如下:
值 | 縮 寫(Sql Server) | Access 和 ASP | 說明 |
Year | Yy | yyyy | 年 1753 ~ 9999 |
Quarter | q | 季 1 ~ 4 | |
Month | Mm | m | 月1 ~ 12 |
Day of year | Dy | y | 一年的日數(shù),一年中的第幾日 1-366 |
Day | Dd | d | 日,1-31 |
Weekday | Dw | w | 一周的日數(shù),一周中的第幾日 1-7 |
Week | Wk | ww | 周,一年中的第幾周 0 ~ 51 |
Hour | Hh | h | 時0 ~ 23 |
Minute | Mi | n | 分鐘0 ~ 59 |
Second | Ss | s | 秒 0 ~ 59 |
Millisecond | Ms | - | 毫秒 0 ~ 999 |
access 和 asp 中用date()和now()取得系統(tǒng)日期時間;其中DateDiff,DateAdd,DatePart也同是能用于Access和asp中,這些函數(shù)的用法也類似
舉例:
1.GetDate() 用于sql server :select GetDate()
2.DateDiff('s','2005-07-20′,'2005-7-25 22:56:32′)返回值為 514592 秒
DateDiff('d','2005-07-20′,'2005-7-25 22:56:32′)返回值為 5 天
3.DatePart('w','2005-7-25 22:56:32′)返回值為 2 即星期一(周日為1,周六為7)
DatePart('d','2005-7-25 22:56:32′)返回值為 25即25號
DatePart('y','2005-7-25 22:56:32′)返回值為 206即這一年中第206天
DatePart('yyyy','2005-7-25 22:56:32′)返回值為 2005即2005年
相關(guān)文章
SQL?Server數(shù)據(jù)庫生成與執(zhí)行SQL腳本詳細教程
為了方便可以把需要連續(xù)執(zhí)行的SQL語句寫到一個文本文件中,并且用.SQL作為擴展名,這種文件叫做SQL腳本文件,下面這篇文章主要給大家介紹了關(guān)于SQL?Server數(shù)據(jù)庫生成與執(zhí)行SQL腳本的相關(guān)資料,需要的朋友可以參考下2023-01-01jdbc使用PreparedStatement批量插入數(shù)據(jù)的方法
這篇文章主要介紹了jdbc使用PreparedStatement批量插入數(shù)據(jù)的相關(guān)知識,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04用sql腳本創(chuàng)建sqlserver數(shù)據(jù)庫范例語句
創(chuàng)建sqlserver數(shù)據(jù)庫腳本 范例 ,主要是熟悉下用sql語句創(chuàng)建數(shù)據(jù)庫的代碼。2010-09-09win2003安裝sqlserver 2000提示無法驗證產(chǎn)品密鑰的解決方法
由于腳本之家的安全設(shè)置,刪除了很多安全隱患的東西,也導致了一些軟件安裝出現(xiàn)錯誤,所以建議大家在安裝好軟件再安全設(shè)置。今天就出現(xiàn)了安全sql2000時提示提示無法驗證產(chǎn)品密鑰,下面的具體的解決方法。2011-07-07SQL Server 磁盤請求超時的833錯誤原因及解決方法
這篇文章主要介紹了SQL Server 磁盤請求超時的833錯誤原因及解決方法,需要的朋友可以參考下2017-06-06