iis服务器助手广告
返回顶部
首页 > 资讯 > 精选 >SQL Server中交叉联接怎么用
  • 941
分享到

SQL Server中交叉联接怎么用

2023-06-14 17:06:20 941人浏览 八月长安
摘要

这篇文章给大家分享的是有关SQL Server中交叉联接怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1、交叉联接(cross join)的概念交叉联接是联接查询的第一个阶段,它对两个数据表进行笛卡尔积。即

这篇文章给大家分享的是有关SQL Server中交叉联接怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

1、交叉联接(cross join)的概念

交叉联接是联接查询的第一个阶段,它对两个数据表进行笛卡尔积。即第一张数据表每一行与第二张表的所有行进行联接,生成结果集的大小等于T1*T2。

select * from t1 cross join t2

2、交叉联接的语法格式

SQL Server中交叉联接怎么用

select * from t1 cross join t2;--常用写法 select * from t1, t2;-- sql:1989的规范 select * from t1 cross join t2 where t1.col1=t2.col2;--等价于内部联接 select * from t1 inner join t2  on t1.col1=t2.col2

3、交叉查询的使用场景

3.1 交叉联接可以查询全部数据

-- 示例

-- 员工表 CREATE TABLE [dbo].[EmpInfo](   [empId] [int] IDENTITY(1,1) NOT NULL,   [empNo] [varchar](20) NULL,   [empName] [nvarchar](20) NULL,  CONSTRaiNT [PK_EmpInfo] PRIMARY KEY CLUSTERED  (   [empId] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF , ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY]  -- 奖金表 CREATE TABLE [dbo].[SalaryInfo](   [id] [int] IDENTITY(1,1) NOT NULL,   [empId] [int] NULL,   [salary] [decimal](18, 2) NULL,   [seasons] [varchar](20) NULL,  CONSTRAINT [PK_SalaryInfo] PRIMARY KEY CLUSTERED  (   [id] ASC )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF , ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY] -- 季度表 CREATE TABLE [dbo].[Seasons](   [name] [nchar](10) NULL ) ON [PRIMARY]  Go SET IDENTITY_INSERT [dbo].[EmpInfo] ON   INSERT [dbo].[EmpInfo] ([empId], [empNo], [empName]) VALUES (1, N'A001', N'王强') INSERT [dbo].[EmpInfo] ([empId], [empNo], [empName]) VALUES (2, N'A002', N'李明') INSERT [dbo].[EmpInfo] ([empId], [empNo], [empName]) VALUES (3, N'A003', N'张三')  INSERT [dbo].[SalaryInfo] ([id], [empId], [salary], [seasons])  VALUES (1, 1, CAST(3000.00 AS Decimal(18, 2)), N'第一季度') INSERT [dbo].[SalaryInfo] ([id], [empId], [salary], [seasons])  VALUES (2, 3, CAST(5000.00 AS Decimal(18, 2)), N'第一季度') INSERT [dbo].[SalaryInfo] ([id], [empId], [salary], [seasons])  VALUES (3, 1, CAST(3500.00 AS Decimal(18, 2)), N'第二季度') INSERT [dbo].[SalaryInfo] ([id], [empId], [salary], [seasons])  VALUES (4, 3, CAST(3000.00 AS Decimal(18, 2)), N'第二季度 ') INSERT [dbo].[SalaryInfo] ([id], [empId], [salary], [seasons])  VALUES (5, 2, CAST(4500.00 AS Decimal(18, 2)), N'第二季度')  INSERT [dbo].[Seasons] ([name]) VALUES (N'第一季度') INSERT [dbo].[Seasons] ([name]) VALUES (N'第二季度') INSERT [dbo].[Seasons] ([name]) VALUES (N'第三季度') INSERT [dbo].[Seasons] ([name]) VALUES (N'第四季度')  -- 查询每个人每个季度的奖金情况 如果奖金不存在则为0 SELECT a.empName,b.name seasons ,isnull(c.salary,0) salary  FROM EmpInfo a  CROSS JOIN Seasons b LEFT OUTER JOIN SalaryInfo c ON a.empId=c.empId AND b.name=c.seasons

3.2 交叉联接优化查询性能

针对一些情况可以采用交叉联接的方式替代子查询,通过减少子查询造成的多次表扫描,从而可以提高优化查询的性能。

感谢各位的阅读!关于“SQL Server中交叉联接怎么用”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

--结束END--

本文标题: SQL Server中交叉联接怎么用

本文链接: https://www.lsjlt.com/news/274069.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • SQL Server中交叉联接怎么用
    这篇文章给大家分享的是有关SQL Server中交叉联接怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1、交叉联接(cross join)的概念交叉联接是联接查询的第一个阶段,它对两个数据表进行笛卡尔积。即...
    99+
    2023-06-14
  • SQL Server中怎么实现交叉联接和内部联接
    SQL Server中怎么实现交叉联接和内部联接,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。交叉联接(CROSS JOIN)交叉连接是最...
    99+
    2024-04-02
  • SQL Server中交叉联接的用法详解
    目录1、交叉联接(cross join)的概念2、交叉联接的语法格式3、交叉查询的使用场景3.1 交叉联接可以查询全部数据3.2 交叉联接优化查询性能4、总结 今天给大家介绍SQLS...
    99+
    2024-04-02
  • SQL Server中交叉联接的使用方法
    这篇文章主要介绍“SQL Server中交叉联接的使用方法”,在日常操作中,相信很多人在SQL Server中交叉联接的使用方法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”...
    99+
    2024-04-02
  • SQL Server 中怎么交叉表查询case
    SQL Server 中怎么交叉表查询case,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。代码如下所示:表landundertake结构如下...
    99+
    2024-04-02
  • web中高级标签和交叉链接怎么用
    这篇文章给大家分享的是有关web中高级标签和交叉链接怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。对于博客和网站来说很强大但却没被充分使用的工具之一就是给页面或博文做好tag(标签)。要有效的用好 tag ...
    99+
    2023-06-12
  • windows7网络联接红叉叉上不了网该怎么办windows7网络联接红叉叉解决方法
    有的windows7客户察觉自己计算机的互联网连接符号上发生红叉叉上不了网,这样的事情怎么办呢?先查验网络线是否插好啦,是得话就开启运行窗口,键入dcomcnfg进到电脑管理控制面板,开始加入到DCOM配备,寻找netprofm,在它的特性...
    99+
    2023-07-14
  • SQL Server中怎么连接查询
    SQL Server中怎么连接查询,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。什么是连接查询呢?概念:根据两个表或多个表的列之间的关系,从这...
    99+
    2024-04-02
  • DataGrip中怎么连接到SQL Server
    本篇文章给大家分享的是有关DataGrip中怎么连接到SQL Server,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。JetBrains D...
    99+
    2024-04-02
  • Sql Server中怎么使用数据库链接
    本篇文章为大家展示了Sql Server中怎么使用数据库链接,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。  第一种:在 sqlserver 企业管理器中,建立,这...
    99+
    2024-04-02
  • eclipse怎么连接sql server
    要在Eclipse中连接SQL Server,你可以按照以下步骤进行操作:1. 下载并安装JDBC驱动程序:首先,你需要下载适用于S...
    99+
    2023-09-27
    eclipse sql server
  • SQL Server中怎么链接服务器
    今天就跟大家聊聊有关SQL Server中怎么链接服务器,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1、为MySQL建立一个ODBC系统数据源,例...
    99+
    2024-04-02
  • php怎么连接sql server
    在PHP中,可以使用不同的函数来连接SQL Server数据库。根据不同的版本和需求,有以下几种方法可以连接SQL Server。一、mssql_系列函数:主要适用于PHP5.3以下的版本和SQL Server 2000及以上的版本。需要在...
    99+
    2023-09-29
    php android 开发语言
  • 教你怎么用python连接sql server
    先利用pip安装pymssql库 pip install pymssql 具体连接、测试代码: # server默认为127.0.0.1,如果打开了TCP动态端口的需要加上端...
    99+
    2024-04-02
  • C#中怎么连接SQL Server数据库
    今天就跟大家聊聊有关C#中怎么连接SQL Server数据库,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。C#连接SQL Server程序代码:using System.D...
    99+
    2023-06-17
  • sql server中怎么拼接多行数据
    这篇文章将为大家详细讲解有关sql server中怎么拼接多行数据,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1.表结构idtypeproductCode...
    99+
    2024-04-02
  • SQL Server中IP不能连接怎么办
    这篇文章给大家分享的是有关SQL Server中IP不能连接怎么办的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。自己电脑上安装的SQLServer,用了一段时间后要联网发现连接不...
    99+
    2024-04-02
  • ADO.NET 中怎么连接SQL Server数据库
    ADO.NET 中怎么连接SQL Server数据库,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。ADO.NET SQL Server关闭连接我们建议您在使用完...
    99+
    2023-06-17
  • jdbc中怎么连接sql server数据库
    jdbc中怎么连接sql server数据库,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1. 驱动问题:JDBC2005与JDBC2008一...
    99+
    2024-04-02
  • SQL Server中怎么允许远程连接
    SQL Server中怎么允许远程连接,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 1.新建登录 展开服务器名下的“安全性”项,展开“登...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作