
通过 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 字段?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号