如何使用 MySQL 按条件筛选 DISTINCT 字段?

如何使用 mysql 按条件筛选 distinct 字段?

通过 mysql 按条件筛选 distinct 字段

想要按条件筛选 distinct 字段,可以考虑以下方法:

使用 distinct 和子查询

distinct 操作符可以从结果集中去除重复值。结合子查询,可以根据特定条件来筛选字段。

例如,如果要按 domain 字段去重,但要考虑 loc 字段中的 "境内" 和 "境外" 条目,可以这样编写查询:

select distinct domain
from (
  select domain, loc
  from table_name
  where loc = "境外"
) as t1
union all
(
  select domain, loc
  from table_name
  where loc != "境外"
);

使用 case 语句

case 语句可以根据指定的条件来评估表达式的值。利用这个特性,可以创建以下查询:

SELECT DISTINCT domain
FROM table_name
WHERE CASE
  WHEN loc = "境外" THEN domain
  ELSE NULL
END IS NOT NULL;

此查询将返回一个包含所有具有唯一域名的行,同时还考虑 loc 字段中的 "境外" 条目。

以上就是如何使用 MySQL 按条件筛选 DISTINCT 字段?的详细内容,更多请关注其它相关文章!