背景
有两张表,要根据视频链接做纽带进行关联,关联之后进行修改
但是萤石云官方更新之后视频链接做了更改,导致两表根据链接匹配时出现问题。但经过对比链接发现链接中的设备标识码还是相同的,所以本文的主要目的就是两表间根据某列中部分字段经行联合查询。
本案例用的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
结果
然后后面的就是关联查询 ,自己可以看一下代码,最后就是修改了,理解了这个过程思路应该也就有了。
总结
用了子查询,效率肯定差点,但是能干活,非常欢迎有更好的办法来解决这个问题,因为之前我也搜了好久。