MySQL equivalent of DECODE function in Oracle(MySQL 相当于 Oracle 中的 DECODE 函数)
问题描述
我试图在 MySQL 中找到等效的 DECODE 函数.它是这样工作的:
I am trying to find an equivalent of DECODE function in MySQL. It works like this:
Select Name, DECODE(Age,
13,'Thirteen',14,'Fourteen',15,'Fifteen',16,'Sixteen',
17,'Seventeen',18,'Eighteen',19,'Nineteen',
'Adult') AS AgeBracket
FROM Person
DECODE 函数会将列 'Age' 的值与 13、14、15.. 进行比较,并返回适当的字符串值 'Thirteen'、'Fourteen'.. 如果没有匹配,则默认值为 'Adult'将被退回.
The DECODE function will compare value of column 'Age' with 13, 14, 15.. and return appropriate string value 'Thirteen', 'Fourteen'.. and if it matches with nothing, then default value of 'Adult' will be returned.
有什么想法可以在 MySQL 中的哪个函数中完成这项工作?谢谢.
Any ideas which function in MySQL can do this job? Thanks.
澄清:我同意使用 CASE 是实现预期结果的一种方式,但出于性能和其他原因,我更愿意寻找函数.
CLARIFICATION: I agree using CASE is one way of achieving desired result, but I am rather looking for a function because of performance and other reasons.
推荐答案
您可以使用 IF(),而在 Oracle 中您会使用 DECODE().
You can use IF() where in Oracle you would have used DECODE().
mysql> select if(emp_id=1,'X','Y') as test, emp_id from emps;
这篇关于MySQL 相当于 Oracle 中的 DECODE 函数的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:MySQL 相当于 Oracle 中的 DECODE 函数
基础教程推荐
- 如何在 CakePHP 3 中实现 INSERT ON DUPLICATE KEY UPDATE aka upsert? 2021-01-01
- ORA-01830:日期格式图片在转换整个输入字符串之前结束/选择日期查询的总和 2021-01-01
- MySQL 5.7参照时间戳生成日期列 2022-01-01
- 带有WHERE子句的LAG()函数 2022-01-01
- 使用 VBS 和注册表来确定安装了哪个版本和 32 位 2021-01-01
- MySQL根据从其他列分组的值,对两列之间的值进行求和 2022-01-01
- 带更新的 sqlite CTE 2022-01-01
- 从字符串 TSQL 中获取数字 2021-01-01
- CHECKSUM 和 CHECKSUM_AGG:算法是什么? 2021-01-01
- while 在触发器内循环以遍历 sql 中表的所有列 2022-01-01
