sql入门经典之连接查询

AIの海雅 AIの海雅     2022-07-28     417

关键词:

上一篇介绍到查询。这一篇主要讲连接查询,将介绍INNER JOIN,OUTER JOIN(LEFT和RIGHT),FULL JOIN,CROSS JOIN。

连接顾名斯义就是把多个数据表数据合并到一个结果集。

用内部连接检索匹配的数据(inner join)

连接结构语法如下:SELECT <column list> FROM <first table>  <join_type> <last table> [ON <join condition>]

接着上面的。经理又有了新需求。要求你查看每个商品的订单日期,先看下面的3条需求代码:

复制代码
select p.ProductID,p.Name,o.UnitPrice,o.OrderQty,o.ModifiedDate FROM Production.Product AS p inner join Sales.SalesOrderDetail AS o ON p.ProductID=o.ProductID --查询到121317条数据集

select p.*,o.UnitPrice,o.OrderQty,o.ModifiedDate FROM Production.Product AS p inner join Sales.SalesOrderDetail AS o ON p.ProductID=o.ProductID  -- --查询到121317条数据集(注意看,下面p.*不同。*表示所有列。p表示p的所有列别查询出来

select ProductID,o.UnitPrice,o.OrderQty,o.ModifiedDate FROM Production.Product AS p inner join Sales.SalesOrderDetail AS o ON p.ProductID=o.ProductID
--(无法查询到,运行出现问题:返回了“消息 209,级别 16,状态 1,第 1 行 列名 'ProductID' 不明确。“的错误信息,因为SQL不知道ProductID是那个表的列)
复制代码

先看2个数据表数据(主要讲解外部连接和全连接)

Order
 ID                        Name                      Contact         
1 test3  null
2      test4 1
3   test5 5
4 test 6 2
   Contact  
ID Name      
1 test1
2    test2  
3 test3  
4   test4

 

 

 

 

 

使用外部检索更多数据(outer join)。

外部连接很少用于实际开发。大家也要理解外部连接。

外部连接基本语法和内部连接差不多:SELECT <select column>  FROM <the table you want  to be the left table>  <LEFT|RIGHT>[OUTER] JOIN <table you want  to be the right table  >[ON ] <join condition> OUTER可以简写掉。为了遵循ISO标准化代码所以加上了

复制代码
SELECT o.*,c.* FROM  Order as o inner join Contact AS c on c.id=o.Contact --inner查询只有2条结果。

SELECT o.*,c.* FROM  Order as o left join Contact AS c on c.id=o.Contact --left查询只有4条结果,有2条结果C.ID和C.Name 为NULL,数据没有匹配到所以null。

SELECT o.*,c.* FROM  Order as o right join Contact AS c on c.id=o.Contact --right查询只有4条结果,有2条结果o.ID和o.Name,o.Contact 为NULL,数据没有匹配到所以null。
复制代码

外部连接主要检索孤立数据多

 完全连接(full join)

外部连接几乎很少使用,只要理解这个概念就知道。顾名思义就完全连接就是left和right联合查询。返回2个表的所有数据。没有匹配到值就NULL代替。先看外部连接SQL语句

SELECT o.*,c.* FROM Order AS o FULL JOIN Contact as c ON C.ID=O.Contact-- 共查询到6条数据(按理说应该是4+4=8条数据,因为中间有2条数据匹配到了,所有6条了)

交叉连接(CROSS JOIN)

交叉连接又称笛卡尔连接。这个用的更少,主要用于测试大量数据。打个比方。有2个表。一个是保存姓有100个姓,一个保存名有1000个名。我要100000个姓名。就使用交叉连接了。继续接着上面的那个表。

SELECT o.*,c.* FROM Order AS o CROSS JOIN Contact as c  --就会产生16条数据。数据量有点大就不贴了。

在SQL2000的早期语法。虽然现在不在使用了。现在sql2012版本不在兼容了。碰见也要记得早期语法。

内部连接:SELECT * from Order,Contact where Order.Contact=Contact.ID;用,代替inner join 和where 代替on。

外部连接:SELECT * from Order,Contact where Order.Contact*=Contact.ID;用,代替(left|right) join 和where 代替on,后面条件(*=左连接,=*右连接)

交叉连接:SELECT *from Order,Contact;去掉CROSS JOIN 就可以关键词添加一个,

联合(union)

接着上面表:相对来说比较简单,就是2个表数据合并成一个表(注意2个表数据结构和数据列一样才能UNION)

select ID,Name FORM Contact
UNION (all)
select ID,Name FORM Order
--all是可选参数。如果没有all,2条结果集有重合数据就舍弃取一条,加上all不会舍弃。

 

sql入门经典之数据库基本查询添加更新和删除

使用SQL查询:SQL查询基本语法:SELECT[ALL|DISTINCT] [TOP(<expression>)[PERCENT][WITHTIES]]<columnlist>[FROM<sourcetable(s)/view>][WHERE<restrictivecondition>][GROUDBY<columnnameorex 查看详情

sql入门经典之简介

...第一篇关于学习技术性文章,这段时间会为大家带来是SQL入门学习。希望大家坚持读下去,因为学历有限。我也是初学者。语言表达能力不好和知识点不足,我写的不好,希望大家多多包涵。主要分享给那些想学SQL一个入门教程... 查看详情

sql入门经典之存储过程

存储过程(storedprocedure)有时候称为sproc,它是真正的脚本-或者更准确的说,他是批处理(batch)-它存储于数据库中,而不是淡出的文件中。无论如何,这个比较并不是很确定。存储过程有输出参数,输入参数已及返回值等。而脚本... 查看详情

sql入门经典之事务

事务是什么?事务关键在与其原子性。原子性概念是指可以把一些事情当作一个执行单元来看待。从数据库角度看待。他是指应该全部执行或者全部不执行一条或多条语句的最小组合。当处理数据时候经常确保一件事发生另一件... 查看详情

sql入门经典之自定义函数

UDF和存储过程很类似,用户自定义函数是一组有序的T-SQL语句,这些语句被预先优化和编译,并且可以作为一个单元来测试调用。UDF和存储过程的主要区别在于结果返回方式,为了能支持更多返回值,UDF比存储过程有跟多限制。U... 查看详情

sql入门经典之脚本和批处理

什么是脚本。我们前面学的CREATETABLE<tablename>,USE<databasename>这些都是脚本,为什么用脚本。脚本存储到文件中并且可以重复利用和提取的文件。创建变量:DECLARE语句最常用的语法:DECLARE@<variablename><variabletype>[=va... 查看详情

sql入门经典之创建和修改数据表

本章主要讲如何使用脚本创建数据库;如何使用脚本创建表;如何删除对象和修改对象.CREATE语句:CREATE<objecttype><onjectname>创建数据库基本语法:CREATEDATABASE<databasename>ON[PARIMARY]([NAME=<‘logicalfilename‘>,][FILENAME=‘&... 查看详情

sql入门经典之键和约束

这一篇博客主要讲键的创建,约束的创建。修改对象和删除对象。主键:主键是每行的唯一标识符,必须包含唯一值(因此不能为NULL)。由于主键在关系中数据库的重要性,因此它是所有键和约束中最重要的。一个表最多可以... 查看详情

javascript入门经典(第五版)-清华出版社之“经典”错误

学校教材太烂,于是自己买书。果然是入门经典,开篇就把我惊着了~第九页≯1.4/ch1_example2.html/1<script>2//scriptblock23documentbgcolor="red";4alert("Secondscriptblock");5</script>运行不通过,仔细检查发现1documentbgcolor应为document.bgColor 查看详情

sql数据库语言基础之sqlserver多表连接查询与innerjoin内连接查询

文章目录​​一、简单连接查询​​​​二、多表连接查询​​​​三、INNERJOIN内连接查询​​一、简单连接查询1、直接连接:无连接规则连接两表,得到的是两个表的笛卡尔积。连接后的行数=表1行数*表2行数连接后的列数=表... 查看详情

sql之复杂查询与视图(代码片段)

...言实现关系代数操作1、并-交-差运算2、空值的处理3、内连接、外连接五、SQL语言之视图及其 查看详情

《算法竞赛入门经典》之“算法设计与优化策略”

一。构造法UVA120 StacksofFlapjacksTimeLimit: 3000MS  64bitIOFormat: %lld&%lluSubmit Status uDebugDescriptionBackgroundStacksandQueuesareoftenconsideredthebreadandbutt 查看详情

数据分析入门经典书籍推荐

1、《MySQL必知必会》推荐理由:这本书把SQL写的非常简单,SQL确实也很简单,其实 pandas 就已可以实现很多数据管理的工作,而了解SQL的意义在于融入到实际的数据使用的场景。比如企业的数据,多是以数据库的形式存储... 查看详情

从零开始学sql:where条件查询与连接(代码片段)

...空值判断7.order排序8.聚合函数9.group分组10.limit限制记录11.连接13.自连接13.子查询14.分页1.练习强化查询查询所有字段:select*from表名;查询部分字段:select字段1,字段2…from表名;查 查看详情

sql之经典sql语句大全

经典SQL语句大全一、基础1、说明:创建数据库CREATEDATABASEdatabase-name 2、说明:删除数据库dropdatabasedbname3、说明:备份sqlserver--- 创建备份数据的 deviceUSEmasterEXECsp_addumpdevice‘disk‘,‘testBack‘,‘c:mssql7backupMyNwind_1 查看详情

mysql之连接查询

连接查询:  将多张表(可以大于2张)进行记录的连接(按照某个指定条件进行数据拼接),最终结果是:记录是有可能变化,字段数一定会增加(至少两张的合并)  连接查询的意义:在用户查看数据的时候,需要显示... 查看详情

drill学习笔记之入门体验

简介:ApacheDrill是一个低延迟的分布式海量数据(涵盖结构化、半结构化以及嵌套数据)交互式查询引擎。分布式、无模式(schema-free)是GoogleDremel的开源实现,本质是一个分布式的mpp(大规模并行处理)查询层,支持SQL及一些用于... 查看详情

mysql基础之连接查询(代码片段)

MySQL基础之连接查询使用下面SQL语句创建数据库girls,并在数据库中创建三张表admin,beauty,boys,并插入相关数据。CREATEDATABASE`girls`;USE`girls`;/*Tablestructurefortable`admin`*/DROPTABLEIFEXISTS`admin`;CREATETA 查看详情