关键词:
上一篇介绍到查询。这一篇主要讲连接查询,将介绍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个数据表数据(主要讲解外部连接和全连接)
ID | Name | Contact |
1 | test3 | null |
2 | test4 | 1 |
3 | test5 | 5 |
4 | test 6 | 2 |
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 查看详情