sql取最新的記錄
select*,max(create_time)froma
wherecreate_time<="2017-03-2919:30:36"
groupbyuser_id
這句可以理解為將結果集根據user_id分組,每組取time最大一條記錄。這樣就很好的實現了批量查詢最近記錄,並且僅僅需要遍歷一次表,即使在數據量巨大的情況下也可以在很短的時間查出結果。
(1)sql取最新的記錄擴展閱讀:
SQL數據查詢語句
1、語句語法簡單歸納為:
SELECTselect_list[INTOnew_table_name][FROMtable_source]
[WHEREsearch_condition][GROUPBYgroup_by_expression]
[HAVINGsearch_condition][ORDERBYorder_expression[ASC|DESC]]
2、WITH子句用於指定臨時命名的公用表達式,在單條語句(SELECT、INSERT、UPDATE、DELETE)的語句執行范圍內定義。
3、LIKE關鍵字
用於模糊查詢,通配符有%、_、[]、[^]
%:後面可以跟零個或多個字元
_:匹配任意單個字元
[]:查詢一定范圍內的單個字元,包括兩端數據
[^]:表示不在一定范圍內的單個字元,包括兩端數據
② SQL在分組查詢時,怎麼獲取最新一條記錄
sql如何分組選擇顯示最新的一條數據
首先,該問題對應的SQL如下
select 采購類別,客戶,訂貨總額
from (select 采購類別,客戶,訂貨總額,
row_number() over(partition by 采購類別 order by 訂貨總額 desc) rn
from table_name) awhere rn<=2
;
其次,常用資料庫比如Oracle和Sqlserver都有特定函數完成分組排序的功能,如果需要顯示並列的情況可以用下面另外的2個.
分別有3個類似函數:
row_number() over
這個函數不需要考慮是否並列,哪怕根據條件查詢出來的數值相同也會進行連續排名。也是最常用的函數,排序結果類似於1,2,3,4,5
rank() over
查出指定條件後進行一個排名,但是有一個特點。假如是對學生排名,那麼實用這個函數,成績相同的兩名是並列。排序結果類似於1,2,2,4,5
dense_rank() over
比較特殊,排序結果類似於1,2,2,3,4
③ sql如何提取最新的時間記錄
你要取最新的時間記錄 只要取得最大的時間就行了 max(時間欄位)
如果用oracle 就得轉化一下時間 todate().
④ SQL 如何獲取時間最新的記錄
select top 1 * from table order by dateField desc 按時間倒序排,取第一條就是最新的記錄
⑤ 怎樣在sql表查詢最新10條記錄
select*from
(selecttop10*from表名orderbydate1)table1orderbydate1desc
以上這段sql語句是查詢表中最新的10條記錄
第一步是要按照「日期」降序排列
第二步取前10條