作者热门文章
- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
以下查询返回表 names
中所有 new_name
的结果集
SELECT
CASE
WHEN nickname = '' THEN fullname ELSE nickname END AS new_name,
FROM names
我正在尝试使用以下查询按 new_name
进行搜索
SELECT
CASE
WHEN nickname = '' THEN fullname ELSE nickname END AS new_name,
FROM names
WHERE new_name LIKE '%Joh%'
但是我得到了错误
“where 子句”中的未知列“new_name”
有没有一种方法可以在不使用子查询的情况下使用此功能?
最佳答案
如果您在 where
子句中重复 case
,该语句将起作用:
SELECT
CASE
WHEN nickname = '' THEN fullname ELSE nickname END AS new_name
FROM names
WHERE (CASE WHEN nickname = '' THEN fullname ELSE nickname END) LIKE '%Joh%'
它不会很快,因为它不会使用索引,但它应该可以工作。
更好的方法如下:
SELECT
CASE
WHEN nickname = '' THEN fullname ELSE nickname END AS new_name
FROM names
WHERE (nickname like '%Joh%') or (fullname LIKE '%Joh%')
这将返回相同的结果,但它可以使用 nickname
和 fullname
上的索引,如果您定义它们,EDIT 并更改第二个LIKE
的操作数不使用前导 %
。
关于mysql - 如何根据 CASE 语句的值编写 WHERE 语句?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10081860/
我是一名优秀的程序员,十分优秀!