MySQL两个字段模糊匹配

1.需求:

今天遇到一个业务需求:两张MySQL表做join,两个关联键是包含关系,SQL该怎么实现。

2.思路:

由于两个关联键是包含关系,那么首先想到的就是like模糊匹配。
通常我们见过的like语法都是类似 a like ‘%aa%’; 那么根据这个思路,我们如何实现两个字段模糊匹配呢?

3.方案:

原始表a:
在这里插入图片描述
原始表cp:
在这里插入图片描述
想要的结果:
在这里插入图片描述

select
    a.*,
		cp.*,
    case when cp.config_name is not null then concat(class_lv1,'-',class_lv2) else '-' end as class
from 
(
    SELECT
        config_name,
        cluster
    FROM pf_cost_daily_summary
    WHERE day_id=20230608
    group by day_id,hulk_id,config_name,cluster,cluster_path
)a
left join pf_cost_classproject_hdfs cp on a.cluster=cp.cluster and a.config_name like concat('%',cp.config_name,'%')

4.总结:

两个字段模糊匹配:

a.config_name like concat('%',cp.config_name,'%')
  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
两张MySQL表进行模糊匹配可以使用like语法来实现。首先,需要确保两个关联键是包含关系。可以使用concat函数将关联键拼接成模糊匹配的格式。例如,如果要实现两个字段模糊匹配,可以使用类似以下的语句: ``` SELECT a.*, cp.*, case when cp.config_name is not null then concat(class_lv1,'-',class_lv2) else '-' end as class FROM ( SELECT config_name, cluster FROM pf_cost_daily_summary WHERE day_id=20230608 GROUP BY day_id,hulk_id,config_name,cluster,cluster_path ) a LEFT JOIN pf_cost_classproject_hdfs cp ON a.cluster=cp.cluster AND a.config_name LIKE CONCAT('%',cp.config_name,'%') ``` 这个查询语句中,使用了concat函数将cp.config_name拼接成了模糊匹配的格式,然后使用like语法进行匹配。\[1\] 另外,如果需要求出技能的频率,可以使用类似以下的语句: ``` SELECT skill, COUNT(*) as quantity FROM skill_table st INNER JOIN v_data_clean v ON v.parse2_job_detail LIKE CONCAT('%',st.skill,'%') GROUP BY st.skill ``` 这个查询语句中,使用了concat函数将st.skill拼接成了模糊匹配的格式,然后使用like语法进行匹配,并使用count函数统计频率。\[2\] #### 引用[.reference_title] - *1* [MySQL两个字段模糊匹配](https://blog.csdn.net/weixin_43433596/article/details/131130613)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [MySQL两个表间的模糊查询](https://blog.csdn.net/qq_45927174/article/details/129620770)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值