sql 查詢本年、本月、本日記錄的語(yǔ)句,附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. 當(dāng)前系統(tǒng)日期、時(shí)間
select getdate()
2. dateadd 在向指定日期加上一段時(shí)間的基礎(chǔ)上,返回新的 datetime 值
例如:向日期加上2天
select dateadd(day,2,'2004-10-15′) –返回:2004-10-17 00:00:00.000
3. datediff 返回跨兩個(gè)指定日期的日期和時(shí)間邊界數(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對(duì)照一下
select 當(dāng)前日期=convert(varchar(10),getdate(),120)
,當(dāng)前時(shí)間=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)目前的日期與時(shí)間 |
DateDiff (interval,date1,date2) | 以interval 指定的方式,返回date2 與date1兩個(gè)日期之間的差值 date2-date1 |
DateAdd (interval,number,date) | 以interval指定的方式,加上number之后的日期 |
DatePart (interval,date) | 返回日期date中,interval指定部分所對(duì)應(yīng)的整數(shù)值 |
DateName (interval,date) | 返回日期date中,interval指定部分所對(duì)應(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 | 時(shí)0 ~ 23 |
Minute | Mi | n | 分鐘0 ~ 59 |
Second | Ss | s | 秒 0 ~ 59 |
Millisecond | Ms | - | 毫秒 0 ~ 999 |
access 和 asp 中用date()和now()取得系統(tǒng)日期時(shí)間;其中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號(hào)
DatePart('y','2005-7-25 22:56:32′)返回值為 206即這一年中第206天
DatePart('yyyy','2005-7-25 22:56:32′)返回值為 2005即2005年
相關(guān)文章
SQL語(yǔ)句練習(xí)實(shí)例之七 剔除不需要的記錄行
相信大家肯定經(jīng)常會(huì)把數(shù)據(jù)導(dǎo)入到數(shù)據(jù)庫(kù)中,但是可能會(huì)有些記錄行的所有列的數(shù)據(jù)是null,這為null的數(shù)據(jù)是我們不需要2011-10-10淺談SQL Server 2016里TempDb的進(jìn)步
tempdb:是連接到 SQL Server 實(shí)例的所有用戶都可用的全局資源,它保存所有臨時(shí)表,臨時(shí)工作表,臨時(shí)存儲(chǔ)過程,臨時(shí)存儲(chǔ)大的類型,中間結(jié)果集,表變量和游標(biāo)等。另外,它還用來滿足所有其他臨時(shí)存儲(chǔ)要求.2016-01-01SQL?Server數(shù)據(jù)庫(kù)生成與執(zhí)行SQL腳本詳細(xì)教程
為了方便可以把需要連續(xù)執(zhí)行的SQL語(yǔ)句寫到一個(gè)文本文件中,并且用.SQL作為擴(kuò)展名,這種文件叫做SQL腳本文件,下面這篇文章主要給大家介紹了關(guān)于SQL?Server數(shù)據(jù)庫(kù)生成與執(zhí)行SQL腳本的相關(guān)資料,需要的朋友可以參考下2023-01-01jdbc使用PreparedStatement批量插入數(shù)據(jù)的方法
這篇文章主要介紹了jdbc使用PreparedStatement批量插入數(shù)據(jù)的相關(guān)知識(shí),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-04-04SQL Server中選出指定范圍行的SQL語(yǔ)句代碼
SQL Server中選出指定范圍行的SQL語(yǔ)句代碼寫法實(shí)例2008-07-07用sql腳本創(chuàng)建sqlserver數(shù)據(jù)庫(kù)范例語(yǔ)句
創(chuàng)建sqlserver數(shù)據(jù)庫(kù)腳本 范例 ,主要是熟悉下用sql語(yǔ)句創(chuàng)建數(shù)據(jù)庫(kù)的代碼。2010-09-09win2003安裝sqlserver 2000提示無法驗(yàn)證產(chǎn)品密鑰的解決方法
由于腳本之家的安全設(shè)置,刪除了很多安全隱患的東西,也導(dǎo)致了一些軟件安裝出現(xiàn)錯(cuò)誤,所以建議大家在安裝好軟件再安全設(shè)置。今天就出現(xiàn)了安全sql2000時(shí)提示提示無法驗(yàn)證產(chǎn)品密鑰,下面的具體的解決方法。2011-07-07SQL Server 磁盤請(qǐng)求超時(shí)的833錯(cuò)誤原因及解決方法
這篇文章主要介紹了SQL Server 磁盤請(qǐng)求超時(shí)的833錯(cuò)誤原因及解決方法,需要的朋友可以參考下2017-06-06