有关sql select case when语句的几个例子,可以在 where 子句中使用case语句实现多条件查询,也可以使用select case when语句组合group by与order by 等子句。
select case when语句
case 可能是 sql 中被误用最多的关键字之一。
可以在 where 子句中使用 case。
case 的语法。在一般的 select 中,其语法:
select <mycolumnspec> =
case
when <a> then <somethinga>
when <b> then <somethingb>
else <somethinge>
end
以上语句中,需要用具体的参数代替尖括号中的内容。
例子:
复制代码 代码示例:
use pubs
go
select
title,
'price range' =
case
when price is null then 'unpriced'
when price < 10 then 'bargain'
when price between 10 and 20 then 'average'
else 'gift to impress relatives'
end
from titles
order by price
go
这是 case 的典型用法,但是使用 case 其实可以做更多的事情。
例2,group by 子句中的 case:
复制代码 代码示例:
select 'number of titles', count(*)
from titles
group by
case
when price is null then 'unpriced'
when price < 10 then 'bargain'
when price between 10 and 20 then 'average'
else 'gift to impress relatives'
end
go
甚至还可以组合这些选项,添加一个 order by 子句。
例3:
复制代码 代码示例:
use pubs
go
select
case
when price is null then 'unpriced'
when price < 10 then 'bargain'
when price between 10 and 20 then 'average'
else 'gift to impress relatives'
end as range,
title
from titles
group by
case
when price is null then 'unpriced'
when price < 10 then 'bargain'
when price between 10 and 20 then 'average'
else 'gift to impress relatives'
end,
title
order by
case
when price is null then 'unpriced'
when price < 10 then 'bargain'
when price between 10 and 20 then 'average'
else 'gift to impress relatives'
end,
title
go
注意,为了在 group by 块中使用 case,查询语句需要在 group by 块中重复 select 块中的 case 块。 (www.jb200.com)
除了选择自定义字段之外,在很多情况下 case 都非常有用。再深入一步,你还可以得到你以前认为不可能得到的分组排序结果集
根据这个例子在程序中实现类似的sql语句:
复制代码 代码示例:
select * from jjy_privatebuilding_info order by l1,
case
when l1=0 then 'name'
when l1<>0 then 'id'
else 'pbbh'
end
go
项目中用的是hibernate中的hql语句,我就不写出来了。
问题:上面的查询结果和select * from jjy_privatebuilding_info order by l1的结果是一样的,这是为什么呢??很是不解。我对select case when的理解是:我感觉这个case when then 应该和java程序中的if条件判断一样才对,when后面的表达式相对于java程序中的if条件,而then 后面的值相对于执行if语句后的值。
出现以上的结果,when then 没有起作用,未解。