mysql case when的用法是什么
mysql case when的用法是:1、用作简单搜索,语法为【CASE [col_name] WHEN [value1]】;2、用作搜索函数,语法为【CASE WHEN [expr] THEN [result1]】。
【相关学习推荐:mysql教程(视频)】
mysql case when的用法是:
case when 的语法有两种
简单函数
CASE [col_name] WHEN [value1] THEN [result1]…ELSE [default] END
搜索函数
CASE WHEN [expr] THEN [result1]…ELSE [default] END
这两种语法有什么区别呢?
1、简单函数
CASE [col_name] WHEN [value1] THEN [result1]…ELSE [default] END
枚举这个字段所有可能的值*
SELECT NAME '英雄', CASE NAME WHEN '德莱文' THEN '斧子' WHEN '德玛西亚-盖伦' THEN '大宝剑' WHEN '暗夜猎手-VN' THEN '弩' ELSE '无' END '装备' FROM user_info; 复制代码 复制代码 SELECT NAME '英雄', CASE NAME WHEN '德莱文' THEN '斧子' WHEN '德玛西亚-盖伦' THEN '大宝剑' WHEN '暗夜猎手-VN' THEN '弩' ELSE '无' END '装备' FROM user_info;
2、搜索函数
CASE WHEN [expr] THEN [result1]…ELSE [default] END
搜索函数可以写判断,并且搜索函数只会返回第一个符合条件的值,其他case被忽略
# when 表达式中可以使用 and 连接条件 SELECT NAME '英雄', age '年龄', CASE WHEN age < 18 THEN '少年' WHEN age < 30 THEN '青年' WHEN age >= 30 AND age < 50 THEN '中年' ELSE '老年' END '状态' FROM user_info;
聚合函数 sum 配合 case when 的简单函数实现行转列 SELECT st.stu_id '学号', st.stu_name '姓名', sum( CASE co.course_name WHEN '大学语文' THEN sc.scores ELSE 0 END ) '大学语文', sum( CASE co.course_name WHEN '新视野英语' THEN sc.scores ELSE 0 END ) '新视野英语', sum( CASE co.course_name WHEN '离散数学' THEN sc.scores ELSE 0 END ) '离散数学', sum( CASE co.course_name WHEN '概率论与数理统计' THEN sc.scores ELSE 0 END ) '概率论与数理统计', sum( CASE co.course_name WHEN '线性代数' THEN sc.scores ELSE 0 END ) '线性代数', sum( CASE co.course_name WHEN '高等数学' THEN sc.scores ELSE 0 END ) '高等数学' FROM edu_student st LEFT JOIN edu_score sc ON st.stu_id = sc.stu_id LEFT JOIN edu_courses co ON co.course_no = sc.course_no GROUP BY st.stu_id ORDER BY NULL;
想了解更多编程学习,敬请关注php培训栏目!
以上是mysql case when的用法是什么的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undress AI Tool
免费脱衣服图片

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Stock Market GPT
人工智能驱动投资研究,做出更明智的决策

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

可以通过在GROUP_CONCAT()函数中使用SEPARATOR关键字来自定义分隔符;1.使用SEPARATOR指定自定义分隔符,如SEPARATOR';'可将分隔符改为分号加空格;2.常见示例包括使用管道符'|'、空格''、换行符'\n'或自定义字符串'->'作为分隔符;3.注意分隔符必须为字符串字面量或表达式,且结果长度受group_concat_max_len变量限制,可通过SETSESSIONgroup_concat_max_len=10000;调整;4.SEPARATOR为可选

使用LOCKTABLES可手动锁定表,READ锁允许多会话读但不可写,WRITE锁为当前会话提供独占读写权限且其他会话无法读写;2.锁定仅限当前连接,执行STARTTRANSACTION等命令会隐式释放锁,锁定后只能访问被锁表;3.仅在MyISAM表维护、数据备份等特定场景使用,InnoDB应优先使用事务和行级锁如SELECT...FORUPDATE以避免性能问题;4.操作完成后必须执行UNLOCKTABLES显式释放锁,否则可能导致资源阻塞。

ifnull()inMysqlreturnsthefirstexpressionFressiviationNotnull,eletherTerntherStheSecondexondsexondsexond,makeitiTIDealForPlacingNullValueswithDefaults; forexample,forexample,ifnull(midder_name,'n/a')显示了“

要从MySQL表中选择数据,应使用SELECT语句,1.使用SELECTcolumn1,column2FROMtable_name获取指定列,或使用SELECT*获取所有列;2.使用WHERE子句过滤行,如SELECTname,ageFROMusersWHEREage>25;3.使用ORDERBY对结果排序,如ORDERBYageDESC表示按年龄降序排列;4.使用LIMIT限制返回行数,如LIMIT5返回前5行,或使用LIMIT10OFFSET20实现分页;5.使用AND、OR和括号组合

使用MySQL处理JSON数据可直接在关系型数据库中存储、查询和操作半结构化数据,自5.7版本起支持JSON类型;通过JSON数据类型定义列并插入合法JSON值,MySQL会自动验证语法;可使用JSON_EXTRACT()或->(返回带引号字符串)和->>(返回无引号值)提取数据,如profile->>"$.city"获取城市名;支持通过WHERE子句过滤JSON值,建议使用生成列和索引提升性能,如ADDcityVARCHAR(50)GENERA

thelikeOperatorInmysqlisusedtosearchforpatternsintextdatausingwildcard; 1.使用%tomatchanySequenceOfCharactersOfCharactersOfCharacterSandTomatchasingle字符; 2.Forexample,'john%'findSnemessTartingwithJohn,'%son'findsnamesendingwithson,'%ar%'findsnamescontaingear,'\ _ \ _ \ _ \ _ \ _

UsedeclarecontinueOdeclareexithandLertoSpeCifyErrandlingBehavior,wheReconTinueAllowSexexecutionToproceedToproceedterhandHandTheError,andExitStopSexecutionOfthecurrentBlock; 2.HandleLororSusingSurorSusingSustrorSusingSustrorSusingsSqlStateValues(e.g.g。,'23000'sco)

要检查MySQL表的大小,可以通过查询information_schema.tables获取;具体方法是使用SELECT语句结合data_length和index_length字段并转换为MB单位,可针对单个表、所有表或分别查看数据和索引大小,该方法适用于大多数情况但数值为近似值,对于InnoDB表可能存在差异,最常用且标准的方式是查询information_schema数据库中的tables表以获得结果。
