首页 > 数据库 > mysql教程 > 如何根据行号内连接两个SQL Server表?

如何根据行号内连接两个SQL Server表?

Mary-Kate Olsen
发布: 2025-01-05 01:36:39
原创
831 人浏览过

How to Inner Join Two SQL Server Tables Based on Row Number?

SQL Server 中行号的内联接

目标: 使用两个表的行执行内联接

场景:

考虑两个表 A 和 B,其中包含以下数据:

Table A Table B
RowA Row4
RowB Row3
RowC Row2
RowD Row1

目标是加入基于行号的表并检索以下内容输出:

Table A Table B
RowA Row1
RowB Row2
RowC Row3
RowD Row4

解决方案:

要对行号执行内连接,请使用 ROW_NUMBER() 函数,如下所示:

SELECT A.val, B.val
FROM (
    SELECT val, ROW_NUMBER() OVER (ORDER BY val) AS row_num
    FROM A
) AS A
JOIN (
    SELECT val, ROW_NUMBER() OVER (ORDER BY val) AS row_num
    FROM B
) AS B
ON A.row_num = B.row_num
ORDER BY A.val, B.val;
登录后复制

此查询为每个输入表(A 和 B)创建一个临时表,并根据 val 列为每行分配行号。然后使用 row_num 列连接表,并按两个表中的 val 列对结果进行排序。

其他注意事项:

  • 如果没有具体说明如果需要排序,请从 ROW_NUMBER() 函数中删除 ORDER BY 子句以保留原始行顺序。

SQL Fiddle 演示:

[SQL Fiddle 演示](https://www.sqlfiddle.com/#!18/69540/2 )

以上是如何根据行号内连接两个SQL Server表?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板