SQL根据列中字段的部分匹配进行关联和修改

背景

有两张表,要根据视频链接做纽带进行关联,关联之后进行修改
但是萤石云官方更新之后视频链接做了更改,导致两表根据链接匹配时出现问题。但经过对比链接发现链接中的设备标识码还是相同的,所以本文的主要目的就是两表间根据某列中部分字段经行联合查询。

本案例用的sqlserver,mysql应该也差不多,有需要的可以自己研究下
之前在网上找了很多方法,但都没有实现,这个案例肯定不是最好的方法,但是能解决问题,有需要的可以借鉴一下。
抛砖引玉,有更好的办法欢迎提出来。

表结构如图

表tb_common_device
在这里插入图片描述
表JC_Video
要根据蓝色框起来的部分进行两表关联,将tb_common_device中的设备序列号device_serial 写入表JC_Video中的DeviceSerial。

代码预览

UPDATE JC_Video 
SET JC_Video.DeviceSerial = temp.device_serial 
FROM
	(
	SELECT
		* 
	FROM
		(
		SELECT
			cameraid,
			SUBSTRING (
				Rtmp,
				charindex( 'rtmp://rtmp.open.ys7.com/openlive/', Rtmp ) + 34,
			len( Rtmp ) - charindex( 'rtmp://rtmp.open.ys7.com/openlive/', Rtmp )) AS rt 
		FROM
			JC_Video 
		) AS a,
		(
		SELECT
			device_serial,
			SUBSTRING (
				Rtmp_hd,
				charindex( 'rtmp://rtmp01open.ys7.com/openlive/', Rtmp ) + 35,
			len( Rtmp_hd ) - charindex( 'rtmp://rtmp01open.ys7.com/openlive/', Rtmp_hd )) AS mp 
		FROM
			tb_common_device 
		) AS b 
	WHERE
		a.rt= b.mp 
	) AS temp 
WHERE
	JC_Video.CameraId= temp.cameraid

执行详解

先查JC_Video

SELECT
			cameraid,
			SUBSTRING (
				Rtmp,
				charindex( 'rtmp://rtmp.open.ys7.com/openlive/', Rtmp ) + 34,
			len( Rtmp ) - charindex( 'rtmp://rtmp.open.ys7.com/openlive/', Rtmp )) AS rt 
		FROM
			JC_Video 

结果
在这里插入图片描述

再查tb_common_device

SELECT
			device_serial,
			SUBSTRING (
				Rtmp_hd,
				charindex( 'rtmp://rtmp01open.ys7.com/openlive/', Rtmp ) + 35,
			len( Rtmp_hd ) - charindex( 'rtmp://rtmp01open.ys7.com/openlive/', Rtmp_hd )) AS mp 
		FROM
			tb_common_device 

结果
在这里插入图片描述
然后后面的就是关联查询 ,自己可以看一下代码,最后就是修改了,理解了这个过程思路应该也就有了。

总结

用了子查询,效率肯定差点,但是能干活,非常欢迎有更好的办法来解决这个问题,因为之前我也搜了好久。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值