>데이터 베이스 >MySQL 튜토리얼 >mysql case...when语句的几个用法_MySQL

mysql case...when语句的几个用法_MySQL

WBOY
WBOY원래의
2016-06-01 13:35:591542검색

bitsCN.com


mysql case...when语句的几个用法

 

一般情况下,case ...when都用在select语句中,不过可以在其他子句中使用 

1 在order by子句中进行自定义排序 

Sql代码  

show create table 20130225t1;  

CREATE TABLE `20130225t1` (  

  `id` tinyint(4) NOT NULL AUTO_INCREMENT,  

  `b` char(1) NOT NULL,  

  PRIMARY KEY (`id`)  

) ENGINE=InnoDB  

 

select * from  20130225t1; 

1 甲 

2 丁 

3 乙 

4 丙 

现在想b字段按照甲乙丙丁的顺序排序,直接order by b是不能实现的,正统的做
法可以加一个排序用的字段,按照该字段排序. 

不过可以用case when语句实现 

Sql代码  

select * from  20130225t1   

order by case b when '甲' then 1 when '乙' then 2   

when '丙' then 3 when '丁' then 4 end  

 

1 甲 

3 乙 

4 丙 

2 丁 

 

还有个手段是find_in_set 函数 

Sql代码  

select * from  20130225t1   

order by FIND_IN_SET(b,'甲,乙,丙,丁')  

 

1 甲 

3 乙 

4 丙 

2 丁 

 

2在where子句中用来进行条件查询 

考虑以下两张表 

Sql代码  

show create table 20130225work  

CREATE TABLE `20130225work` (  

  `id` tinyint(4) NOT NULL AUTO_INCREMENT,  

  `role_id` tinyint(4) NOT NULL,  

  `dep_id` tinyint(4) NOT NULL,  

  PRIMARY KEY (`id`)  

) ENGINE=InnoDB  

 

 

Sql代码  

show create table 20130225role  

CREATE TABLE `20130225role` (  

  `id` tinyint(4) NOT NULL,  

  `role_name` varchar(5) DEFAULT NULL,  

  PRIMARY KEY (`id`)  

) ENGINE=InnoDB  

 

 

20130225work是各部门提交上来的申请,role_id是能够看到申请的角色的id,dep_id是提交申请的部门 

20130225role是角色. 

 

select * from  20130225role 

 

1 部门经理 

2 总经理 

 

select * from  20130225work 

1 1 1 

2 1 2 

3 2 1 

4 2 2 

 

现在问题是部门经理角色只能看到自己部门的申请,总经理看到所有部门的申请. 

 

(1)可以在20130225work中加个字段need_check,1表示该申请需要检查部门,0表示不需要 

 

现在要根据role id和dep_id查找该角色对应的申请 

Sql代码  

set @role_id=1;  

set @dept_id=1;  

select * from  20130225work  

where role_id=@role_id and (case need_check   

            when 1 then dep_id=@dept_id  

            else 1=1  

                end)  

 

1 1 1 1 

 

Sql代码  

set @role_id=2;  

set @dept_id=1;  

select * from  20130225work  

where role_id=@role_id and (case need_check   

                    when 1 then dep_id=@dept_id  

                    else 1=1  

                end)  

 

3 2 1 0 

4 2 2 0 

 

(2)或者把need_check加到20130225role中 

Sql代码  

set @role_id=1;  

set @dept_id=2;  

select * from  20130225work w,20130225role r  

where r.id=@role_id and w.role_id=r.id  

                and (case need_check   

                    when 1 then dep_id=@dept_id  

                    else 1=1  

                end)  

 

case when也能在group by语句中出现,只是不知道能有啥作用. 

其实我最希望它能出现在from语句中,就能动态指定from的表.

 

bitsCN.com
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.