常用SQL語句(嵌套子查詢/隨機等等)詳細整理
更新時間:2013年01月24日 16:29:57 作者:
本文整理了一些常用的sql語句:插入語句得到自動生成的遞增ID值實現(xiàn)是1 或0 想顯示為男或女/嵌套子查詢/顯示文章、提交人和最后回復(fù)時間/隨機提取條記錄的例子等等太多了就不一一講了,感興趣的朋友可以聊接下
1.SQL 插入語句得到自動生成的遞增ID值
insert into Table1(Name,des,num) values ('ltp','thisisbest',10);
select @@identity as 'Id'
2.實現(xiàn)是1 或0 想顯示為男或女
select name,Sex=(case Sex when '1' then '男' when '0' then '女' end) from Tablename
3.嵌套子查詢
select a,b,c from Table1 where a IN (select a from Table2)
4.顯示文章、提交人和最后回復(fù)時間
select a.title,a.username,b.adddate from tablename a,(select max(adddate) adddate from tablename where tablename.title=a.title) b
5.隨機提取條記錄的例子
SQL Server:Select Top 10 * From Tablename Order By NewID()
Access:Select Top 10 * From Tablename Order By Rnd(ID)
Rnd(ID) 其中的ID 是自動編號字段,可以利用其他任何數(shù)值來完成,比如用姓名字段UserName
Select Top 10 * From 表Order BY Rnd(Len(UserName))
MySql:Select * From 表Order By Rand() Limit 10
6.在同一表內(nèi)找相同屬性的記錄
select UserID from Accounts_Users where UserName is not null group by UserID having count (*)>1
7.查詢類別所有的產(chǎn)品對應(yīng)數(shù)據(jù)
SELECT CategoryName,ProductName FROM Categories LEFT JOIN Products ON Categories.CategoryID = Products.CategoryID;
8.按范圍查詢編號在2 到5 之間的用戶信息
select * from UserValue where UserID between 2 and 5;
9.日程安排提前5 分鐘提醒
Select * from TabSchedule where datediff(minute,getdate(),開始時間)<5
10.得出某日期所在月份的最大天數(shù)
SELECT DAY(DATEADD(dd, -DAY('2008-02-13'),DATEADD(mm, 1, '2008-02-13'))) AS 'DayNumber'
11.按姓氏筆畫排序
Select * From TableName Order By CustomerName Collate Chinese_PRC_Stroke_ci_as
12.通配符的一些用法
1.select * from tablename where column1 like '[A-M]%' 這樣可以選擇出column 字段中首字母在A-M 之間的記錄
2.select * from tablename where column1 like '[ABC]%' 這樣可以選擇出column 字段中首字母是A 或者B 或者C 的記錄
3.select * from tablename where column1 like '[A-CG]%' 這樣可以選擇出column 字段中首字母在A-C 之間的或者是G 的記錄
4.select * from tablename where column1 like '[^C]%' 這樣可以選擇出column 字段中首字母不是C 的記錄
13.復(fù)制表結(jié)構(gòu)(只復(fù)制結(jié)構(gòu),源表名:a,目標表名:b)
select * into b from a where 1<>1 或 select top 0 * into [b] from [a]
14.復(fù)制表數(shù)據(jù)(復(fù)制數(shù)據(jù),源表名:a,目標表名:b)
insert into b(Name,des,num) select Name,des,num from Table1;
復(fù)制代碼 代碼如下:
insert into Table1(Name,des,num) values ('ltp','thisisbest',10);
select @@identity as 'Id'
2.實現(xiàn)是1 或0 想顯示為男或女
復(fù)制代碼 代碼如下:
select name,Sex=(case Sex when '1' then '男' when '0' then '女' end) from Tablename
3.嵌套子查詢
復(fù)制代碼 代碼如下:
select a,b,c from Table1 where a IN (select a from Table2)
4.顯示文章、提交人和最后回復(fù)時間
復(fù)制代碼 代碼如下:
select a.title,a.username,b.adddate from tablename a,(select max(adddate) adddate from tablename where tablename.title=a.title) b
5.隨機提取條記錄的例子
復(fù)制代碼 代碼如下:
SQL Server:Select Top 10 * From Tablename Order By NewID()
Access:Select Top 10 * From Tablename Order By Rnd(ID)
Rnd(ID) 其中的ID 是自動編號字段,可以利用其他任何數(shù)值來完成,比如用姓名字段UserName
Select Top 10 * From 表Order BY Rnd(Len(UserName))
MySql:Select * From 表Order By Rand() Limit 10
6.在同一表內(nèi)找相同屬性的記錄
復(fù)制代碼 代碼如下:
select UserID from Accounts_Users where UserName is not null group by UserID having count (*)>1
7.查詢類別所有的產(chǎn)品對應(yīng)數(shù)據(jù)
復(fù)制代碼 代碼如下:
SELECT CategoryName,ProductName FROM Categories LEFT JOIN Products ON Categories.CategoryID = Products.CategoryID;
8.按范圍查詢編號在2 到5 之間的用戶信息
復(fù)制代碼 代碼如下:
select * from UserValue where UserID between 2 and 5;
9.日程安排提前5 分鐘提醒
復(fù)制代碼 代碼如下:
Select * from TabSchedule where datediff(minute,getdate(),開始時間)<5
10.得出某日期所在月份的最大天數(shù)
復(fù)制代碼 代碼如下:
SELECT DAY(DATEADD(dd, -DAY('2008-02-13'),DATEADD(mm, 1, '2008-02-13'))) AS 'DayNumber'
11.按姓氏筆畫排序
復(fù)制代碼 代碼如下:
Select * From TableName Order By CustomerName Collate Chinese_PRC_Stroke_ci_as
12.通配符的一些用法
復(fù)制代碼 代碼如下:
1.select * from tablename where column1 like '[A-M]%' 這樣可以選擇出column 字段中首字母在A-M 之間的記錄
2.select * from tablename where column1 like '[ABC]%' 這樣可以選擇出column 字段中首字母是A 或者B 或者C 的記錄
3.select * from tablename where column1 like '[A-CG]%' 這樣可以選擇出column 字段中首字母在A-C 之間的或者是G 的記錄
4.select * from tablename where column1 like '[^C]%' 這樣可以選擇出column 字段中首字母不是C 的記錄
13.復(fù)制表結(jié)構(gòu)(只復(fù)制結(jié)構(gòu),源表名:a,目標表名:b)
復(fù)制代碼 代碼如下:
select * into b from a where 1<>1 或 select top 0 * into [b] from [a]
14.復(fù)制表數(shù)據(jù)(復(fù)制數(shù)據(jù),源表名:a,目標表名:b)
復(fù)制代碼 代碼如下:
insert into b(Name,des,num) select Name,des,num from Table1;
相關(guān)文章
SQL Server數(shù)據(jù)庫自動收縮配置指南
在數(shù)據(jù)庫管理中,隨著數(shù)據(jù)的增刪,數(shù)據(jù)庫文件的大小會不斷變化,導(dǎo)致空間浪費和性能下降,SQL Server提供了自動收縮功能,本文將深入探討如何在SQL Server中配置數(shù)據(jù)庫的自動收縮,需要的朋友可以參考下2024-07-07
大數(shù)據(jù)量高并發(fā)的數(shù)據(jù)庫優(yōu)化詳解
這篇文章主要介紹了大數(shù)據(jù)量高并發(fā)的數(shù)據(jù)庫優(yōu)化,需要的朋友可以參考下2015-08-08
SQLServer行列互轉(zhuǎn)實現(xiàn)思路(聚合函數(shù))
這篇文章主要為大家詳細介紹了SQLServer行列互轉(zhuǎn)實現(xiàn)思路,使用聚合函數(shù)pivot/unpivot實現(xiàn)行列互轉(zhuǎn),感興趣的小伙伴們可以參考一下2016-03-03
Sql Server數(shù)據(jù)庫實現(xiàn)表中字段的列加密
本文主要介紹了Sql Server數(shù)據(jù)庫實現(xiàn)表中字段的列加密,主要包括利用證書對數(shù)據(jù)進行加密和解密,利用非對稱密鑰對數(shù)據(jù)進行加密和解密,利用對稱密鑰對數(shù)據(jù)進行加密和解密,感興趣的可以了解一下2023-10-10
清除SQL?Server數(shù)據(jù)庫日志(ldf文件)的方法匯總
隨著系統(tǒng)運行時間的推移,數(shù)據(jù)庫日志文件會變得越來越大,這時我們需要對日志文件進行備份或清理,這篇文章主要介紹了清除SQL?Server數(shù)據(jù)庫日志(ldf文件)的幾種方法,需要的朋友可以參考下2022-10-10

