如何使用 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 字段中的 “境外” 条目。

© 版权声明
THE END
喜欢就支持一下吧
点赞6 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容