如何使用 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 字段?的详细内容,更多请关注其它相关文章!