最新活动:电脑PC端+手机端+微网站+自适应网页多模板选择-建站388元起价!!!
当前位置:主页 > 网站建设 > 基于SQL Server中如何比较两个表的各组数据 图解说

基于SQL Server中如何比较两个表的各组数据 图解说

时间:2023-05-23 22:05:23 阅读: 文章分类: 网站建设 作者: 网站技术员

导读:1建站知识本篇文章小编为大家介绍,基于SQL Server中如何比较两个表的各组数据 图解说明。需要的朋友参考下seo网站优化培训网站seo优化。

seo网站优化培训网站seo优化

开始

前一阵子,在项目中碰到这样一个SQL查询需求,有两个相同结构的表(table_left & table_right),如下:

网站建设多少钱

图1.

检查表table_left的各组(groupId),是否在表table_right中存在有一组(groupId)数据(data)与它的数据(data)完全相等.

如图1. 可以看出表table_left和table_right存在两组数据完整相等:

图2.

分析

从上面的两个表,可以知道它们存放的是一组一组的数据;那么,接下来我借助数学集合的列举法和运算进行分析。

seo网站优化软件

先通过集合的列举法描述两个表的各组数据:

图3.

这里只有两种情况,相等和不相等。对于不相等,可再分为部分相等、包含、和完全不相等。使用集合描述,可使用交集,子集,并集。如下面图4.,我列举出这几种常见的情况:

图4.

实现

在数据库中,要找出表table_left和表table_right存在相同数据的组,方法很多,这里我列出两种常用的方法。

(下面的SQL脚本,是以图4.的数据为基础参考)

方法1:

通过"Select … From …Order by … xml for path('') "把各组的data列数据连串起来(如,图4.把table_left的组#11的列data连串起来成"data1-data2-data3"),其他分组(包含表table_right)以此方法实现data列数据连串起来;然后通过比较两表的连串后字段是否存在相等,若是相等就说明这比较多两组数据相等,由此可以判断出表table_left的哪组数据在表table_right存在与它数据完全相等的组。

针对方法1,需要对原表增加一个字段dataPath,用于存储data列数据连串的结果,如:

复制代码 代码如下:

alter table table_left add dataPath nvarchar(200) alter table table_right add dataPath nvarchar(200)

分组连串data列数据并update至刚新增的列dataPath,如:

复制代码 代码如下:

update a set dataPath=b.dataPath from table_left a cross apply(select (select '-'+x.data from table_left x where x.groupId=a.groupId order by x.data for xml path('')) as dataPath)b update a set dataPath=b.dataPath from table_right a cross apply(select (select '-'+x.data from table_right x where x.groupId=a.groupId order by x.data for xml path('')) as dataPath)b

接下来就是查询了,如:

复制代码 代码如下:

select distinct a.groupId from table_left a where exists(select 1 from table_right x where x.dataPath=a.dataPath)

完整代码:

复制代码 代码如下:

关键词标签: 标签 两个 SQL

声明: 本文由我的SEOUC技术文章主页发布于:2023-05-23 ,文章基于SQL Server中如何比较两个表的各组数据 图解说主要讲述两个,标签,SQL网站建设源码以及服务器配置搭建相关技术文章。转载请保留链接: https://www.seouc.com/article/web_6069.html

我的IDC 网站建设技术SEOUC.COM
专注网站建设,SEO优化,小程序设计制作搭建开发定制网站等,数千家网站定制开发案例,网站推广技术服务。
  • 5000+合作客服
  • 8年从业经验
  • 150+覆盖行业
  • 最新热门源码技术文章