SQL:使用 CASE

使用 CASE
CASE 函数是特殊的 Transact-SQL 表达式,它允许按列值显式可选值。数据中的更改是临时的,没有对数据进行永久更改。例如,CASE 函数可以在 state 列中有 CA 值的行的查询结果集内显示 California。

CASE 函数包含:

CASE 关键字。


需要转换的列名称。


指定要搜索的表达式的 WHEN 子句和指定要替换它们的表达式的 THEN 子句。


END 关键字。


可选的、定义 CASE 函数别名的 AS 子句。
下面示例在查询结果集内显示每个作者所居住州的全名:

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();
    }

转载于:https://www.cnblogs.com/focustea/archive/2007/08/02/840620.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值