SQL:使用 CASE
使用 CASE
CASE 函數(shù)是特殊的 Transact-SQL 表達式,它允許按列值顯式可選值。數(shù)據(jù)中的更改是臨時的,沒有對數(shù)據(jù)進行永久更改。例如,CASE 函數(shù)可以在 state 列中有 CA 值的行的查詢結果集內(nèi)顯示 California。
CASE 函數(shù)包含:
CASE 關鍵字。
需要轉(zhuǎn)換的列名稱。
指定要搜索的表達式的 WHEN 子句和指定要替換它們的表達式的 THEN 子句。
END 關鍵字。
可選的、定義 CASE 函數(shù)別名的 AS 子句。
下面示例在查詢結果集內(nèi)顯示每個作者所居住州的全名:
SELECT au_fname, au_lname,
?? CASE state
????? WHEN 'CA' THEN 'California'
????? WHEN 'KS' THEN 'Kansas'
????? WHEN 'TN' THEN 'Tennessee'
????? WHEN 'OR' THEN 'Oregon'
????? WHEN 'MI' THEN 'Michigan'
????? WHEN 'IN' THEN 'Indiana'
????? WHEN 'MD' THEN 'Maryland'
????? WHEN 'UT' THEN 'Utah'
??????? END AS StateName
FROM pubs.dbo.authors
ORDER BY au_lname
?Eg:
?/// <summary>
??? /// 綁定使用積分列表
??? /// </summary>
??? private void BindGainPoint()
??? {
??????? string strCommand = " SELECT UseDate,UsePointCount,OrderID,CASE PonitType WHEN 1 THEN '注冊' WHEN 2 THEN '機票' WHEN 3 THEN '酒店' WHEN 4 THEN '旅游' END AS PonitType? ";
??????? strCommand += " FROM point_use ";
??????? strCommand += " ORDER BY UseDate DESC ";
??????? SqlResult sr = Broker.Execute(strCommand);
??????? DataTable dt = ObjectView.GetDataView(sr).Table;
??????? this.gv_Use.DataSource = dt;
??????? this.gv_Use.DataBind();
??? }
??? /// <summary>
??? /// 綁定獲得積分列表
??? /// </summary>
??? private void BindUsePoint()
??? {
??????? string strCommand = " SELECT Number,OrderID,CASE PonitType WHEN 1 THEN '注冊' WHEN 2 THEN '機票' WHEN 3 THEN '酒店' WHEN 4 THEN '旅游' END AS PonitType, ";
??????? strCommand += " CASE Status WHEN 0 THEN '未激活' WHEN 1 THEN '已激活' WHEN 2 THEN '已失效' END AS Status,Validate,GainDate ";
??????? strCommand += " FROM point_gain ";
??????? strCommand += " ORDER BY GainDate DESC ";
??????? SqlResult sr = Broker.Execute(strCommand);
??????? DataTable dt = ObjectView.GetDataView(sr).Table;
??????? this.gv_Gain.DataSource = dt;
??????? this.gv_Gain.DataBind();
??? }
轉(zhuǎn)載于:https://www.cnblogs.com/focustea/archive/2007/08/02/840620.html
總結
以上是生活随笔為你收集整理的SQL:使用 CASE的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 石油知识
- 下一篇: AIR工程中发生This applica