程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> 其他數據庫知識 >> 更多數據庫知識 >> 常用SQL語句(嵌套子查詢/隨機等等)詳細整理

常用SQL語句(嵌套子查詢/隨機等等)詳細整理

編輯:更多數據庫知識

1.SQL 插入語句得到自動生成的遞增ID值
復制代碼 代碼如下:
insert into Table1(Name,des,num) values ('ltp','thisisbest',10);
select @@identity as 'Id'

2.實現是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.顯示文章、提交人和最後回復時間
復制代碼 代碼如下:
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 是自動編號字段,可以利用其他任何數值來完成,比如用姓名字段UserName

Select Top 10 * From 表Order BY Rnd(Len(UserName))

MySql:Select * From 表Order By Rand() Limit 10

6.在同一表內找相同屬性的記錄
復制代碼 代碼如下:
select UserID from Accounts_Users where UserName is not null group by UserID having count (*)>1

7.查詢類別所有的產品對應數據
復制代碼 代碼如下:
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.得出某日期所在月份的最大天數
復制代碼 代碼如下:
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.復制表結構(只復制結構,源表名:a,目標表名:b)
復制代碼 代碼如下:
select * into b from a where 1<>1 或 select top 0 * into [b] from [a]

14.復制表數據(復制數據,源表名:a,目標表名:b)
復制代碼 代碼如下:
insert into b(Name,des,num) select Name,des,num from Table1;

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved