两表关联字段模糊匹配查询

最近发现一个比较恶心的问题,由于业务或是其他不可说的原因(各位读者自行脑补)的问题导致原有存储的数据发生变动;与现有数据有差别,如原有的数据名称发生变动,但是还要对数据进行匹配(此时你的内心犹如无数羊驼狂奔而过。唉,为了XX,还是要处理呀),来看数据,

先介绍一下表,

</
原表名/新表名 字段名及其解释 注释
z_good
列名 类型 解释
id varchar(50) id,主键id
name varchar(255) 名称
remark varchar(255) 备注或描述
newmc varchar(255) 新名称

旧表
z_good_new
类型 解释
newid varchar(50) id,主键id
mc varchar(255) 名称
ms varchar(255) 描述
新表
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
两张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 ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值