使用 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

SQL:使用 CASE相关推荐

  1. SQL中Case和convert()

    SQL语句之 case 和 convert 一.SQL之case 1 1.基本用法 :作为sql语句中的判断条件 case 字段 when 条件1 THEN 结果 Else 结果 END 2.比较用法 ...

  2. 了解SQL Server CASE语句

    SQL Server CASE statement is equivalent to the IF-THEN statement in Excel. SQL Server CASE语句等效于Excel ...

  3. SQL之case when then用法(用于分类统计)

    case具有两种格式.简单case函数和case搜索函数. --简单case函数 case sexwhen '1' then '男' when '2' then '女' else '其他' end - ...

  4. SQL中case的使用方法

    Case具有两种格式.简单Case函数和Case搜索函数. 1.简单Case函数 CASE sex WHEN '1' THEN '男'WHEN '2' THEN '女' ELSE '其他' END 2 ...

  5. SQL语句--CASE函数写法的简单举例,及应用

    SQL语句–CASE函数写法的简单举例,及应用 ---case函数的基本结构:case when...then...else... ----可以写也可以不写,按实际需求end [举个栗子_1] eg1 ...

  6. Case When语句详解SQL中Case When的用法

    SQL中case when的用法 case when类似于编程语言中的if else判断.switch case语句.该语句执行时先对条件进行判断,然后根据判断结果做出相应的操作. Case具有两种格 ...

  7. 【SQL中case then的用法】

    SQL中case then的用法   当我们需要从数据源上直接判断数据显示代表的含义的时候 ,就可以在SQL语句中使用CASE THEN这个函数了.   其中case then有两种格式: 1.第一种 ...

  8. 关于sql中case when的用法

    Oracle CASE WHEN 用法介绍 1. CASE WHEN 表达式有两种形式 --简单Case函数 CASE sex WHEN '1' THEN '男' WHEN '2' THEN '女' ...

  9. Tuning SQL via case when statement

    原SQL如下:SQL的主要问题是红色部分居然通过标量查询,反复的查找与SQL相同的基表,很显然这个可以用case when来简化. select a.TRAN_ID,a.AMOUNT,a.BALANC ...

  10. case when用法java,sql之case when用法详解

    简单CASE WHEN函数只能应对一些简单的业务场景,而CASE WHEN条件表达式的写法则更加灵活. CASE WHEN条件表达式函数:类似JAVA中的IF ELSE语句. 简单CASE WHEN函 ...

最新文章

  1. vs2010快捷方式
  2. Android性能优化——腾讯、字节、阿里、百度、网易等互联网公司项目实战+案例分析(附PDF)
  3. Visual C++ Attribute Programming
  4. 4、Docker 提交运行中容器作为新的镜像
  5. 想成为一名优秀的Web前端工程师,这5点你要知道
  6. 在C#中如何定义一个变长的结构数组?如果定义好了,如何获得当前数组的长度?...
  7. matlab 正则化表达式_MATLAB 正则表达式(一)(转)
  8. MySQL 常见索引的使用场景与区别(SQL小技巧)
  9. jsp中jstl标签的类似 if - else 语句 的语法
  10. Django:Django简介,MTV,Django常用命令
  11. python软件下载-python软件下载
  12. 企业微信好不好,OA软件何去何从?
  13. python好学吗-非科班出身自学Python好学吗?
  14. 中专学校计算机科目试讲稿,中专10分钟试讲教案模板
  15. QGraphicsItem图元拖动绘制(二)
  16. 不会侧方停车?看看这6张图简单学会!
  17. 牛客网入门题--最大公约数与最小公倍数
  18. antd Upload组件使用,出现闪动问题
  19. 线程通信和进程通信区别(线程进程区别)
  20. 计算机绘图千斤顶,AUTO CAD课程设计实验报告.doc

热门文章

  1. 搞定高并发,岂能不懂Synchronized底层原理?
  2. 一道泄露并遭禁用的谷歌面试题,背后玄机全解析
  3. 程序员需要能show出来!
  4. Docker 核心概念、安装、端口映射及常用操作命令,详细到令人发指。
  5. JVM:内存划分总结
  6. 【Python】青少年蓝桥杯_每日一题_1.27_单词出现的次数
  7. org.hibernate.NonUniqueObjectException 异常处理
  8. java强制编译通过_强制java使用用户输入作为消息进行编译错误
  9. 在mysql中怎样设置值唯一_mysql怎么设置行值唯一?
  10. linux java性能监控工具_性能监控工具以及java堆分析OOM