程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> 基於sql語句的一些常用語法積累總結

基於sql語句的一些常用語法積累總結

編輯:MySQL綜合教程

1.當某一字段的值希望通過其它字值顯示出來時(記錄轉換),可通過下面的語句實現:
case Type when '1' then '普通通道' when '2' then '高端通道' end as Type
其中“Type"是字段名,”1“,”2“是字段值

2.返回數據庫中用戶表的表單名:
select name from table where type = 'u' and status >=2

3.按拼音首字母排序:
select * from table order by 列名 Collate Chinese_PRC_CS_AS_KS_WS
首先,在這裡的collate是一個子句,主要是定義排序規則,可應用於數據庫定義或列定義;或應用於字符串表達式以應用排序規則投影。
語法是collate   collation_name。參數collate_name是應用於表達式、列定義或數據庫定義的排序規則的名稱。
•collation_name 可以只是指定的 Windows_collation_name 或 SQL_collation_name。
1.Windows_collation_name 是 Windows 排序規則的排序規則名稱。參見 Windows 排序規則名稱。
2.SQL_collation_name 是 SQL 排序規則的排序規則名稱。參見 SQL 排序規則名稱。
注:SQL  SERVER的排序規則平時使用不是很多,也許不少初學者還比較陌生,但有 一個錯誤大家應是經常碰到: SQL SERVER數據庫,在跨庫多表連接查詢時,若兩數據 庫默認字符集不同,系統就會返回這樣的錯誤:“無法解決 equal to 操作的排序規則沖突。”

4.按姓氏筆畫排序:
Select * From table Order By CustomerName Collate Chinese_PRC_Stroke_ci_as
注釋如上。

5.指定值的范圍查詢:
1.stockname like ‘%[a-zA-Z]%'
2.stockname like '[^F-M]‘
其中
[]
指定值的范圍
^ 排除指定范圍

6.對查詢結果隨機排序:
SELECT * FROM  table Orders ORDER BY NEWID()

7.返回兩個表中共有的所有記錄:
select tableA.a tableB.b from tableA  inner join tableB as b ontableA.a= b.b
其中sql中as的用法這裡就不做熬述。

8.等待時間再執行語句:
復制代碼 代碼如下:
waitfor delay '00:00:05‘
select * from studentinfowaitfor time '23:08:00

9.向一個表A中插入記錄,並且插入的記錄在A中不存在(通過一個字段來判斷):
復制代碼 代碼如下:
insert into tableA (tracekey,muteSMS,CreateTime,traceuser,tracetime,traceSlot,traceduration)
Select 'TRACE_TIMER',0,getdate(),mobileid,getdate(),'30','0' from tableB where corpid = 10001
and not exists (select traceuser from tableA ) and mobileid like '13' and len(mobileid) = 11

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