mysql中LOCATE和CASE WHEN...THEN...ELSE...END结合用法

之前项目中需要写一个sql,就是查出某个调研详情中,选A答案,B答案,C答案...F答案的人各有多少人,这个sql也是费了很大的力气才写出来,故记下来,方便以后使用。

其中tbl_research_item为调研详情表,tbl_user_research_item为用户答题详情表

SELECT item.research_id,item.item_id,item.question,item.question_type,item.option1,item.option2,item.option3,item.option4,item.option5,item.option6,
sum(CASE WHEN (LOCATE(‘A‘, uitem.choose_option) > 0) THEN 1 ELSE 0 END) as option1AnsCnt,
sum(CASE WHEN (LOCATE(‘B‘, uitem.choose_option) > 0) THEN 1 ELSE 0 END) as option2AnsCnt,
sum(CASE WHEN (LOCATE(‘C‘, uitem.choose_option) > 0) THEN 1 ELSE 0 END) as option3AnsCnt,
sum(CASE WHEN (LOCATE(‘D‘, uitem.choose_option) > 0) THEN 1 ELSE 0 END) as option4AnsCnt,
sum(CASE WHEN (LOCATE(‘E‘, uitem.choose_option) > 0) THEN 1 ELSE 0 END) as option5AnsCnt,
sum(CASE WHEN (LOCATE(‘F‘, uitem.choose_option) > 0) THEN 1 ELSE 0 END) as option6AnsCnt
FROM tbl_research_item item
LEFT JOIN tbl_user_research_item uitem ON (item.research_id=uitem.research_id and item.item_id=uitem.item_id)
WHERE item.research_id = ‘10093‘
and question_type != ‘input‘
GROUP BY item.item_id

由于每道调研的题目有可能为多选,也就是说,uitem.choose_option的值有可能为AB这样的,所以呢,这个sql的思路是当uitem.choose_option中先‘A’的位置大于0,就表示选了A,也就是记为1,否则为0,再将所有用户选了A的数量求和,因此得到了这个调研中这到题选A的总人数option1AnsCnt,其他的以此类推。

在这里顺便介绍一下sql中遇到的LOCATE和CASE WHEN...THEN...ELSE...END两个函数的用法:

1.LOCATE(substr,str) :返回子串 substr 在字符串 str 中第一次出现的位置。如果子串 substr 在 str 中不存在,返回值为 0

例如:select LOCATE(‘d‘, ‘asdfghj‘)    --->3

2.CASE WHEN...THEN...ELSE...END

例如:

SELECT                case                   -------------如果    when sex=‘1‘ then ‘男‘ -------------sex=‘1‘,则返回值‘男‘    when sex=‘2‘ then ‘女‘ -------------sex=‘2‘,则返回值‘女‘      else ‘其他‘            -------------其他的返回‘其他’    end                   -------------结束
这个函数还有另外一种写法:
CASE sex
         WHEN ‘1‘ THEN ‘男‘
         WHEN ‘2‘ THEN ‘女‘
ELSE ‘其他‘ END

这两种写法都是可以的
时间: 2024-08-09 19:52:49

mysql中LOCATE和CASE WHEN...THEN...ELSE...END结合用法的相关文章

mysql中计算两个日期的时间差函数TIMESTAMPDIFF用法

mysql中计算两个日期的时间差函数TIMESTAMPDIFF用法: 语法: TIMESTAMPDIFF(interval,datetime_expr1,datetime_expr2) 说明: 返回日期或日期时间表达式datetime_expr1 和datetime_expr2the 之间的整数差.其结果的单位由interval 参数给出.interval 的法定值同TIMESTAMPADD()函数说明中所列出的相同. mysql> SELECT TIMESTAMPDIFF(MONTH,'200

MySQL中授权(grant)和撤销授权(revoke)命令之用法

MySQL的权限系统围绕着两个概念: 认证->确定用户是否允许连接数据库服务器 授权->确定用户是否拥有足够的权限执行查询请求等. 如果认证不成功的话,哪么授权肯定是无法进行的. revoke 跟 grant 的语法差不多,只需要把关键字 "to" 换成 "from" 表 GRANT和REVOKE管理的权限 权限 描述 ALL PRIVILEGES 影响除WITH GRANT OPTION之外的所有权限 ALTER 影响ALTER TABLE命令的使用

mysql中concat和case问题

1.使用concat,如果某列为空,那么concat的结果也为空 解决方案 IFNULL(kh.`build_name`,'') IFNULL函数,如果为空则用后面设定的值 2.使用case when时 CASE kh.`unit_name` WHEN NULL THEN ''ELSE '-' END 上面的sql无法判断是否为空 CASE WHEN kh.`unit_name` IS NULL THEN ''ELSE '-' END 应使用   is null来判断 原文地址:https://

(13)mysql中的流程控制

概述 在mysql中可以使用if/case/loop/leave/iterate/repeat/while语句进行流程控制. if语句 if语句实现条件判断,类似高级语言(c/c++/php/java等)中的if语句. if search_condition then statement_list [elseif search_condition then statement_list]... [else statement_list] end if 举例 if mobile='13911113

SQLserver中ISNULL函数与Mysql中IFNULL函数的用法

本文介绍下,sql server中的isnull函数,以及mysql中的ifnull函数,介绍二者的具体用法与区别,有兴趣的朋友可以研究下哦. 先来看SQL Serve的ISNULL函数: ISNULL(check_expression,replacement_value) 1.check_expression与replacement_value的数据类型必须一致. 2.如果check_expression为NULL,则返回replacement_value. 3.如果check_express

shell脚本中if与case使用,查找文件locate与find的使用,压缩,解压及归档工具

shell脚本中if与case使用 查找文件locate与find的使用 压缩,解压及归档工具 执行的循序  顺序执行  选择执行  循环执行 条件语句if if只是一个有含义的词,不能单独作为指令使用. 单分支 if 条件判断:then 条件为真的分支代码 fi 双分支 if 判断条件:then 条件为真的分支代码 else 条件为假的分支代码 fi 多分支 if 判断条件1, if-true elif 判断条件2,then if-ture elif 判断条件3,then if-ture ..

MySQL中CASE的使用

语法说明: 方式一: CASE value WHEN [compare_value] THEN result [WHEN [compare_value] THEN result ...] [ELSE result] END 方式二: CASE WHEN [condition] THEN result [WHEN [condition] THEN result ...] [ELSE result] END 使用演示样例: mysql> select id,name, (gender) as '性别

函数:MySQL中字符串匹配函数LOCATE和POSITION使用方法

1. 用法一 LOCATE(substr,str) POSITION(substr IN str) 函数返回子串substr在字符串str中第一次出现的位置.如果子串substr在str中不存在,返回值为0. mysql> SELECT LOCATE('bar', 'foobarbar'); -> 4 mysql> SELECT LOCATE('xbar', 'foobar'); -> 0 这个函数是大小写不敏感的.在MySQL3.23中,这个函数是字母大小写敏感的,当在MySQL

MySQL中比like语句更高效的写法locate position instr find_in_set

你是否一直在寻找比MySQL的LIKE语句更高效的方法的,下面我就为你介绍几种. LIKE语句 SELECT `column` FROM `table` where `condition` like`%keyword%' 事实上,可以使用 locate(position) 和 instr这两个函数来代替 LOCATE语句 SELECT `column` from `table` where locate('keyword',`condition`)>0 或是 locate 的別名 positio