Ⅰ sql 查詢表所有數據,貨品有重復的取日期較早的一條
select distinct 名稱, 狀態, 時間 from 表 where 狀態 = 1 order by 時間 desc
應該是樓主想要的~ 有重復的會按照時間取第一條~
Ⅱ 求sql,查詢所有日期中每個日期最早的記錄
select a.* from table a,(select clrq,min(dqsj) as dqsj from table group by clrq) b where a.clrq=b.clrq and a.dqsj=b.dqsj
Ⅲ sql 語句選擇日期最早的
您好,這樣的:
CREATE TABLE AAA (姓名 C(10),性別 C(2),培訓時間 D)
INSERT INTO AAA VALUES ("ABC","男",{^1999.01.02})
INSERT INTO AAA VALUES ("ACD","男",{^2001.01.02})
INSERT INTO AAA VALUES ("ABF","男",{^1999.11.02})
INSERT INTO AAA VALUES ("ABC","男",{^2000.01.02})
INSERT INTO AAA VALUES ("ABF","男",{^1999.09.02})
INSERT INTO AAA VALUES ("ACD","男",{^1999.01.02})
SELECT 姓名,性別 ,MIN(培訓時間) AS 培訓時間 FROM AAA GROUP BY 姓名,性別
select 姓名,性別,min(培訓時間) as 培訓時間 from 表 group by 姓名,性別
-- or --
select 姓名,性別,min(培訓時間) as 培訓時間 from 表 group by 姓名,性別 order by 姓名
-- or --
select 姓名,性別,min(培訓時間) as 培訓時間 from 表 group by 姓名,性別 order by 3
Ⅳ 在SQL 語句中如果想讀取早於一個時間點的所有數據 sql語句該怎麼寫
oracle:
select * from table as of timestamp sysdate-5/1440;
表示讀取距今5分鍾的數據,也即前五分鍾的數據啦,其他類似。
Ⅳ sql中取時間最早對應的記錄
在資料庫應用開發中,我們經常需要面對復雜的SQL式計算,固定分組就是其中一種。固定分組的分組依據不在待分組的數據中,而是來自於外部,比如另一張表、外部參數、條件列表等。對於特定類型的固定分組,用SQL實現還算簡單(比如:分組依據來自另一張表,且對分組次序沒有要求),但對於比較通用、靈活的要求,實現起來就困難了。
而對於SPL來說,完全可以輕松解決固定分組中的各類難題,下面就用幾個例子來說明。
表sales存儲著訂單記錄,其中CLIENT列是客戶名,AMOUNT列是訂單金額。表sales的部分數據如下:
.png
要求將sales按照「潛力客戶列表」進行分組,並對各組的AMOUNT列匯總求和。這里的「潛力客戶」就是一種固定分組,可能來自於外部不同的條件設定:
案例一:潛力客戶列表來自於另外一張表potential的Std欄位,只有四條記錄,依次為:ANATR、BERGS、LACOR、ZTOZ,並且客戶ZTOZ不在sales表中。在輸出結果時,要求按照上述記錄順序來分組匯總。
如果我們對分組的順序沒有要求,那麼SQL可以較簡單地實現本案例:
select potential.std as client, sum(sales.amount) as amount from potential left join client on potential.std=sales.client group by potential.std。
但如果像本案例中要求的那樣,按照特定的順序來分組,那麼用SQL實現的話就必須製造一個用於排序的欄位,最後還要用子查詢去掉這個欄位。而用SPL實現則會簡單很多
Ⅵ sql中取時間最早對應的記錄
假如你的表,
accno
只有一個
12的。
沒有其他的
accno。
或者你無視
accno,
只找時間最早的那條。
那麼:
SELECT
TOP
1
*
FROM
表名
ORDER
BY
opdate,
optime;
假如你的表,有很多個
accno,
比如有
12,
13,
你要
分別把
12
與
13
的時間最早對應的記錄查出來。
SELECT
*
FROM
表名
WHERE
NOT
EXISTS
(
SELECT
1
FROM
表名
AS
tmp
WHERE
表名.accno
=
tmp.accno
AND
表名.opdate
>
tmp.opdate
AND
表名.optime
>
tmp.optime
);
理解起來,就是查詢
表
對於每一個
accno,
不存在有其他的行,比當前行的
opdate
與
optime
更加小的。
從而取得
每一個
accno
的,日期時間最早的記錄。
Ⅶ 使用sql語句查詢日期的方法
使用sql語句查詢日期的方法
結構化查詢語言(Structured Query Language)簡稱SQL,是一種特殊目的的編程語言,是一種資料庫查詢和程序設計語言,用於存取數據以及查詢、更新和管理關系資料庫系統。以下是我為大家整理的使用sql語句查詢日期的方法,僅供參考,希望能夠幫助大家。
使用sql語句查詢日期的方法 篇1
使用sql語句查詢日期
select * from ShopOrder where datediff(week,ordTime,getdate()-1)=0 //查詢當天日期在一周年的數據
--查詢當天:
select * from info where DateDiff(dd,datetime,getdate())=0
--查詢24小時內的:
select * from info where DateDiff(hh,datetime,getDate())<=24
--info為表名,datetime為資料庫中的欄位值
--查詢當天:
select * from info where DateDiff(dd,datetime,getdate())=0
--查詢24小時內的:
select * from info where DateDiff(hh,datetime,getDate())<=24 --info為表名,datetime為資料庫中的欄位值
Sql代碼
--查詢當天記錄另類的方法
SELECT *
FROM j_GradeShop
WHERE (GAddTime BETWEEN CONVERT(datetime, LEFT(GETDATE(), 10) + ' 00:00:00.000')
AND CONVERT(datetime, LEFT(GETDATE(), 10) + ' 00:00:00.000') + 1) ORDER BY GAddTime DESC
--查詢當天記錄另類的方法
SELECT *
FROM j_GradeShop
WHERE (GAddTime BETWEEN CONVERT(datetime, LEFT(GETDATE(), 10) + ' 00:00:00.000')
AND CONVERT(datetime, LEFT(GETDATE(), 10) + ' 00:00:00.000') + 1) ORDER BY GAddTime DESC
DATEDIFF 函數:
語法:
DATEDIFF ( datepart , startdate , enddate )
備注:enddate 減去 startdate。如果 startdate 晚於 enddate,則返回負值。 如果結果超出整數值范圍,則 DATEDIFF 將產生錯誤。對於毫秒,最大數是 24 天 20 小時 31 分鍾零 23.647 秒。對於秒,最大數是 68 年。
跨分鍾、秒和毫秒等邊界計算的方法使得 DATEDIFF 指定的結果在所有數據類型中均一致。結果是帶正負號的整數值,它等於跨第一個和第二個日期間的
datepart 邊界數。例如,在 1 月 4 日(星期日)和 1 月 11 日(星期日)之間的'星期數是 1。
可以再MSSQL中測試:
Sql代碼
--兩個時間差剛好是24
--列印的方式
print dateDiff(hh,'2009-1-1 0:0:0','2009-1-2 0:0:0')
--查詢的方式
print dateDiff(hh,'2009-1-1 0:0:0','2009-1-2 0:0:0')
--兩個時間差剛好是24
--列印的方式
print dateDiff(hh,'2009-1-1 0:0:0','2009-1-2 0:0:0')
--查詢的方式
print dateDiff(hh,'2009-1-1 0:0:0','2009-1-2 0:0:0')
Sql代碼
--本月記錄
SELECT * FROM 表 WHERE datediff(month,[dateadd],getdate())=0
--本周記錄
SELECT * FROM 表 WHERE datediff(week,[dateadd],getdate())=0
--包括本年這些查詢方式是一樣的
--本月記錄
SELECT * FROM 表 WHERE datediff(month,[dateadd],getdate())=0
--本周記錄
SELECT * FROM 表 WHERE datediff(week,[dateadd],getdate())=0
--包括本年這些查詢方式是一樣的
sql server中的時間函數
1. 當前系統日期、時間
select getdate()
2. dateadd 在向指定日期加上一段時間的基礎上,返回新的 datetime 值 例如:向日期加上2天
select dateadd(day,2,'2004-10-15') --返回:2004-10-17 00:00:00.000
3. datediff 返回跨兩個指定日期的日期和時間邊界數。
select datediff(day,'2004-09-01','2004-09-18') --返回:17
4. datepart 返回代表指定日期的指定日期部分的整數。
SELECT DATEPART(month, '2004-10-15') --返回 10
5. datename 返回代表指定日期的指定日期部分的字元串
SELECT datename(weekday, '2004-10-15') --返回:星期五
6. day(), month(),year() --可以與datepart對照一下
select 當前日期=convert(var10),getdate(),120)
,當前時間=convert(var8),getdate(),114)
select datename(dw,'2004-10-15')
select 本年第多少周=datename(week,'2004-10-15')
,今天是周幾=datename(weekday,'2004-10-15')
函數 參數/功能
GetDate( ) 返回系統目前的日期與時間
DateDiff (interval,date1,date2) 以interval 指定的方式,返回date2 與date1兩個日期之間的差值 date2-date1
DateAdd (interval,number,date) 以interval指定的方式,加上number之後
的日期
DatePart (interval,date) 返回日期date中,interval指定部分所對應的整數值
DateName (interval,date) 返回日期date中,interval指定部分所對應的字元串名稱
參數 interval的設定值如下:
值 縮 寫(Sql Server) Access 和 ASP 說明
Year Yy yyyy 年 1753 ~ 9999
Quarter Qq q 季 1 ~ 4
Month Mm m 月1 ~ 12
Day of year Dy y 一年的日數,一年中的第幾日 1-366
Day Dd d 日,1-31
Weekday Dw w 一周的日數,一周中的第幾日 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()取得系統日期時間;其中
DateDiff,DateAdd,DatePart也同是能用於Access和asp中,這些函數的用法也類似
舉例:
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年
使用sql語句查詢日期的方法 篇2
datediff(week,zy_time,getdate())=0 //查詢本周 datediff(month,zy_time,getdate())=0 //查詢本月
本季:select * from table where datediff(qq,C_CALLTIME,getdate())=0
前半年1-6,後半年7-12:select * from table where datepart(mm,C_CALLTIME)/7 = datepart(mm,getdate())/7 1. 當前系統日期、時間 select getdate()
2. dateadd 在向指定日期加上一段時間的基礎上,返回新的 datetime 值 例如:向日期加上2天
select dateadd(day,2,'2004-10-15') --返回:2004-10-17 00:00:00.000 3. datediff 返回跨兩個指定日期的日期和時間邊界數。
select datediff(day,'2004-09-01','2004-09-18') --返回:17 4. datepart 返回代表指定日期的指定日期部分的整數。 SELECT DATEPART(month, '2004-10-15') --返回 10 5. datename 返回代表指定日期的指定日期部分的字元串 SELECT datename(weekday, '2004-10-15') --返回:星期五 6. day(), month(),year() --可以與datepart對照一下 select 當前日期=convert(var10),getdate(),120) ,當前時間=convert(var8),getdate(),114) select datename(dw,'2004-10-15')
select 本年第多少周=datename(week,'2004-10-15') ,今天是周幾=datename(weekday,'2004-10-15') 函數 GetDate( )
參數/功能
返回系統目前的日期與時間
以interval 指定的方式,返回
DateDiff
date2 與date1兩個日期之間的
(interval,date1,date2)
差值 date2-date1 DateAdd 以interval指定的方式,加上(interval,number,date) number之後的日期
返回日期date中,interval指定
DatePart (interval,date)
部分所對應的整數值 返回日期date中,interval指定
DateName (interval,date)
部分所對應的字元串名稱
參數 interval的設定值如下:
Access 和
縮 寫(Sql Server)
ASP Yy Qq Mm
yyyy q m y d w ww h n s -
值 Year Quarter Month
說明
年 1753 ~ 9999 季 1 ~ 4 月1 ~ 12
一年的日數,一年中的第幾日 1-366 日,1-31
一周的日數,一周中的第幾日 1-7
周,一年中的第幾周 0 ~ 51 時0 ~ 23 分鍾0 ~ 59 秒 0 ~ 59 毫秒 0 ~ 999
Day of year Dy Day Weekday Week Hour Minute Second
Dd Dw Wk Hh Mi Ss
Millisecond Ms
access 和 asp 中用date()和now()取得系統日期時間;其中DateDiff,DateAdd,DatePart也同是能用於Access和asp中,這些函數的用法也類似
舉例:
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年 sql 查詢本周本月問題 ---求相差天數
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
--如果要效率,這樣寫查詢
--查詢本周注冊人數
where
create_day>=dateadd(day,2-datepart(weekday,getdate()),convert(varchar,getdate(),112)) and
create_day<dateadd(day,9-datepart(weekday,getdate()),convert(varchar,getdate(),112))
--上周注冊人數
select count(*) from [user] where
create_day>=dateadd(day,-5-datepart(weekday,getdate()),convert(varchar,getdate(),112)) and
create_day<dateadd(day,2-datepart(weekday,getdate()),convert(varchar,getdate(),112))
--本月注冊人數
select count(*) from [user]
where 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)))
--上月注冊人數
select count(*) from [user] where
create_day>=dateadd(month,-1,dateadd(day,1-day(getdate()),convert(varchar,getdate(),112)))
and create_day<dateadd(day,1-day(getdate()),convert(varchar,getdate(),112))
--本周
select count(*) from User
where datediff(dd,create_day,getdate()) <= datepart(dw,getdate())
--上周
select count(*) from User
where datediff(dd,create_day,(getdate() - datepart(dw,getdate()))) <= 7
--本月
select count(*) from User
where datepart(mm,create_day) = datepart(mm,getdate()) --上月
where datepart(mm,create_day) = datepart(mm,getdate()) - 1 --本周
select count(*) from [User]
where datediff(dd,create_day,getdate()) <= datepart(dw,getdate())
--上周
select count(*) from [User]
where datediff(dd,create_day,(getdate() - datepart(dw,getdate()))) <= 7
--本月
select count(*) from [User]
where datepart(mm,create_day) = datepart(mm,getdate()) --上月
select count(*) from [User]
where datepart(mm,create_day) = datepart(mm,getdate()) - 1 學習
month(create_day)=month(getdate())本月 month(create_day)=month(getdate())-1 上月
補充 查詢今日所有的
SELECT * from feedback WHERE (DATEDIFF(d,fedtime,GETDATE())=0) ORDER BY fedid DESC
;Ⅷ sql取最早和最後時間
例如員工列名為worker,時間列名為time,表名為tableName,那麼可得結果
selectworker,min([time])as最早時間,max([time])as最後時間
fromtableName
groupbyworker
whereworker='員工a'