SQL入门新手教程重要

上传人:痛*** 文档编号:111611362 上传时间:2022-06-21 格式:DOC 页数:105 大小:931KB
收藏 版权申诉 举报 下载
SQL入门新手教程重要_第1页
第1页 / 共105页
SQL入门新手教程重要_第2页
第2页 / 共105页
SQL入门新手教程重要_第3页
第3页 / 共105页
资源描述:

《SQL入门新手教程重要》由会员分享,可在线阅读,更多相关《SQL入门新手教程重要(105页珍藏版)》请在装配图网上搜索。

1、 SQL 是用于访问和处理数据库的标准的计算机语言。什么是 SQL? SQL 指结构化查询语言 SQL 使我们有能力访问数据库 SQL 是一种 ANSI 的标准计算机语言 编者注:ANSI,美国国家标准化组织SQL 能做什么? SQL 面向数据库执行查询 SQL 可从数据库取回数据 SQL 可在数据库中插入新的纪录 SQL 可更新数据库中的数据 SQL 可从数据库删除记录 SQL 可创立新数据库 SQL 可在数据库中创立新表 SQL 可在数据库中创立存储过程 SQL 可在数据库中创立视图 SQL 可以设置表、存储过程和视图的权限 SQL 是一种标准 - 但是.SQL 是一门 ANSI 的标准计

2、算机语言,用来访问和操作数据库系统。SQL 语句用于取回和更新数据库中的数据。SQL 可与数据库程序协同工作,比方 MS Access、DB2、Informix、MS SQL Server、Oracle、Sybase 以与其他数据库系统。不幸地是,存在着很多不同版本的 SQL 语言,但是为了与 ANSI 标准相兼容,它们必须以相似的方式共同地来支持一些主要的关键词比方 SELECT、UPDATE、DELETE、INSERT、WHERE 等等。注释:除了 SQL 标准之外,大局部 SQL 数据库程序都拥有它们自己的私有扩展!在您的中使用 SQL要创立发布数据库中数据的,您需要以下要素: RDBM

3、S 数据库程序比方 MS Access, SQL Server, MySQL 效劳器端脚本语言比方 PHP 或 ASP SQL HTML / CSS RDBMSRDBMS 指的是关系型数据库管理系统。RDBMS 是 SQL 的根底,同样也是所有现代数据库系统的根底,比方 MS SQL Server, IBM DB2, Oracle, MySQL 以与 Microsoft Access。RDBMS 中的数据存储在被称为表tables的数据库对象中。表是相关的数据项的集合,它由列和行组成。SQL 语法数据库表一个数据库通常包含一个或多个表。每个表由一个名字标识例如“客户或者“订单。表包含带有数据的

4、记录行。下面的例子是一个名为 Persons 的表:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetBeijing上面的表包含三条记录每一条对应一个人和五个列Id、姓、名、地址和城市。SQL 语句您需要在数据库上执行的大局部工作都由 SQL 语句完成。下面的语句从表中选取 LastName 列的数据:SELECT LastName FROM Persons在本教程中,我们将为您讲解各种不同的 SQL 语句。重要

5、事项一定要记住,SQL 对大小写不敏感!SQL 语句后面的分号?某些数据库系统要求在每条 SQL 命令的末端使用分号。在我们的教程中不使用分号。分号是在数据库系统中分隔每条 SQL 语句的标准方法,这样就可以在对效劳器的一样请求中执行一条以上的语句。如果您使用的是 MS Access 和 SQL Server 2000,那么不必在每条 SQL 语句之后使用分号,不过某些数据库软件要求必须使用分号。SQL DML 和 DDL可以把 SQL 分为两个局部:数据操作语言 (DML) 和 数据定义语言 (DDL)。 SQL (结构化查询语言)是用于执行查询的语法。但是 SQL 语言也包含用于更新、插入

6、和删除记录的语法。查询和更新指令构成了 SQL 的 DML 局部: SELECT - 从数据库表中获取数据 UPDATE - 更新数据库表中的数据 DELETE - 从数据库表中删除数据 INSERT INTO - 向数据库表中插入数据 SQL 的数据定义语言 (DDL) 局部使我们有能力创立或删除表格。我们也可以定义索引键,规定表之间的,以与施加表间的约束。SQL 中最重要的 DDL 语句: CREATE DATABASE - 创立新数据库 ALTER DATABASE - 修改数据库 CREATE TABLE - 创立新表 ALTER TABLE - 变更改变数据库表 DROP TABLE

7、 - 删除表 CREATE INDEX - 创立索引搜索SQL SELECT 语句本章讲解 SELECT 和 SELECT * 语句。SQL SELECT 语句SELECT 语句用于从表中选取数据。结果被存储在一个结果表中称为结果集。SQL SELECT 语法SELECT 列名称 FROM 表名称以与:SELECT * FROM 表名称注释:SQL 语句对大小写不敏感。SELECT 等效于 select。SQL SELECT 实例如需获取名为 LastName 和 FirstName 的列的容从名为 Persons 的数据库表,请使用类似这样的 SELECT 语句:SELECT LastNam

8、e,FirstName FROM PersonsPersons 表:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetBeijing结果:LastNameFirstNameAdamsJohnBushGeorgeCarterThomasSQL SELECT * 实例现在我们希望从 Persons 表中选取所有的列。请使用符号 * 取代列的名称,就像这样:SELECT * FROM Persons提示:星号*是选取所

9、有列的快捷方式。结果:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetBeijing在结果集result-set中导航由 SQL 查询程序获得的结果被存放在一个结果集中。大多数数据库软件系统都允许使用编程函数在结果集中进展导航,比方:Move-To-First-Record、Get-Record-Content、Move-To-Next-Record 等等。类似这些编程函数不在本教程讲解之列。如需学习通过函数调

10、用访问数据的知识,请访问我们的 ADO 教程 和 PHP 教程。SQL SELECT DISTINCT 语句本章讲解 SELECT DISTINCT 语句。SQL SELECT DISTINCT 语句在表中,可能会包含重复值。这并不成问题,不过,有时您也许希望仅仅列出不同distinct的值。关键词 DISTINCT 用于返回唯一不同的值。语法:SELECT DISTINCT 列名称 FROM 表名称使用 DISTINCT 关键词如果要从 Company 列中选取所有的值,我们需要使用 SELECT 语句:SELECT Company FROM OrdersOrders表:CompanyOrd

11、erNumberIBM3532W3School2356Apple4698W3School6953结果:CompanyIBMW3SchoolAppleW3School请注意,在结果集中,W3School 被列出了两次。如需从 Company 列中仅选取唯一不同的值,我们需要使用 SELECT DISTINCT 语句:SELECTDISTINCT Company FROM Orders 结果:CompanyIBMW3SchoolApple现在,在结果集中,W3School 仅被列出了一次。SQL WHERE 子句WHERE 子句用于规定选择的标准。WHERE 子句如需有条件地从表中选取数据,可将

12、WHERE 子句添加到 SELECT 语句。语法SELECT 列名称 FROM 表名称 WHERE 列 运算符 值下面的运算符可在 WHERE 子句中使用:操作符描述=等于不等于大于=大于等于=小于等于BETWEEN在某个围LIKE搜索某种模式注释:在某些版本的 SQL 中,操作符 可以写为 !=。使用 WHERE 子句如果只希望选取居住在城市 Beijing 中的人,我们需要向 SELECT 语句添加 WHERE 子句:SELECT * FROM PersonsWHERECity=BeijingPersons 表LastNameFirstNameAddressCityYearAdamsJoh

13、nOxford StreetLondon1970BushGeorgeFifth AvenueNew York1975CarterThomasChangan StreetBeijing1980GatesBillXuanwumen 10Beijing1985结果:LastNameFirstNameAddressCityYearCarterThomasChangan StreetBeijing1980GatesBillXuanwumen 10Beijing1985引号的使用请注意,我们在例子中的条件值周围使用的是单引号。SQL 使用单引号来环绕文本值大局部数据库系统也承受双引号。如果是数值,请不要使

14、用引号。文本值:这是正确的:SELECT * FROM Persons WHERE FirstName=Bush这是错误的:SELECT * FROM Persons WHERE FirstName=Bush数值:这是正确的:SELECT * FROM Persons WHERE Year1965这是错误的:SELECT * FROM Persons WHERE Year1965SQL AND & OR 运算符AND 和 OR 运算符用于基于一个以上的条件对记录进展过滤。AND 和 OR 运算符AND 和 OR 可在 WHERE 子语句中把两个或多个条件结合起来。如果第一个条件和第二个条件都成

15、立,那么 AND 运算符显示一条记录。如果第一个条件和第二个条件中只要有一个成立,那么 OR 运算符显示一条记录。原始的表 (用在例子中的):LastNameFirstNameAddressCityAdamsJohnOxford StreetLondonBushGeorgeFifth AvenueNew YorkCarterThomasChangan StreetBeijingCarterWilliamXuanwumen 10BeijingAND 运算符实例使用 AND 来显示所有姓为 Carter 并且名为 Thomas 的人:SELECT * FROM Persons WHERE Firs

16、tName=Thomas AND LastName=Carter结果:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingOR 运算符实例使用 OR 来显示所有姓为 Carter 或者名为 Thomas 的人:SELECT * FROM Persons WHERE firstname=Thomas OR lastname=Carter结果:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingCarterWilliamXuanwumen 10Beijing结

17、合 AND 和 OR 运算符我们也可以把 AND 和 OR 结合起来使用圆括号来组成复杂的表达式:SELECT * FROM Persons WHERE (FirstName=Thomas OR FirstName=William)AND LastName=Carter结果:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingCarterWilliamXuanwumen 10BeijingSQL ORDER BY 子句ORDER BY 语句用于对结果集进展排序。ORDER BY 语句ORDER BY 语句用于根据指定的列对结

18、果集进展排序。ORDER BY 语句默认按照升序对记录进展排序。如果您希望按照降序对记录进展排序,可以使用 DESC 关键字。原始的表 (用在例子中的):Orders 表:CompanyOrderNumberIBM3532W3School2356Apple4698W3School6953实例 1以字母顺序显示公司名称:SELECT Company, OrderNumber FROM Orders ORDER BY Company结果:CompanyOrderNumberApple4698IBM3532W3School6953W3School2356实例 2以字母顺序显示公司名称Company,

19、并以数字顺序显示顺序号OrderNumber:SELECT Company, OrderNumber FROM Orders ORDER BY Company, OrderNumber结果:CompanyOrderNumberApple4698IBM3532W3School2356W3School6953实例 3以逆字母顺序显示公司名称:SELECT Company, OrderNumber FROM Orders ORDER BY Company DESC结果:CompanyOrderNumberW3School6953W3School2356IBM3532Apple4698实例 4以逆字母

20、顺序显示公司名称,并以数字顺序显示顺序号:SELECT Company, OrderNumber FROM Orders ORDER BY Company DESC, OrderNumber ASC结果:CompanyOrderNumberW3School2356W3School6953IBM3532Apple4698注意:在以上的结果中有两个相等的公司名称 (W3School)。只有这一次,在第一列中有一样的值时,第二列是以升序排列的。如果第一列中有些值为 nulls 时,情况也是这样的。SQL INSERT INTO 语句INSERT INTO 语句INSERT INTO 语句用于向表格中

21、插入新的行。语法INSERT INTO 表名称 VALUES (值1, 值2,.)我们也可以指定所要插入数据的列:INSERT INTO table_name (列1, 列2,.) VALUES (值1, 值2,.)插入新的行Persons 表:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingSQL 语句:INSERT INTO Persons VALUES (Gates, Bill, Xuanwumen 10, Beijing)结果:LastNameFirstNameAddressCityCarterThomasCha

22、ngan StreetBeijingGatesBillXuanwumen 10Beijing在指定的列中插入数据Persons 表:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingGatesBillXuanwumen 10BeijingSQL 语句:INSERT INTO Persons (LastName, Address) VALUES (Wilson, Champs-Elysees)结果:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingGat

23、esBillXuanwumen 10BeijingWilsonChamps-ElyseesSQL UPDATE 语句Update 语句Update 语句用于修改表中的数据。语法:UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值Person:LastNameFirstNameAddressCityGatesBillXuanwumen 10BeijingWilsonChamps-Elysees更新某一行中的一个列我们为 lastname 是 Wilson 的人添加 firstname:UPDATE Person SET FirstName = Fred WHERE La

24、stName = Wilson 结果:LastNameFirstNameAddressCityGatesBillXuanwumen 10BeijingWilsonFredChamps-Elysees更新某一行中的假设干列我们会修改地址address,并添加城市名称city:UPDATE Person SET Address = Zhongshan 23, City = NanjingWHERE LastName = Wilson结果:LastNameFirstNameAddressCityGatesBillXuanwumen 10BeijingWilsonFredZhongshan 23Nan

25、jingSQL DELETE 语句DELETE 语句DELETE 语句用于删除表中的行。语法DELETE FROM 表名称 WHERE 列名称 = 值Person:LastNameFirstNameAddressCityGatesBillXuanwumen 10BeijingWilsonFredZhongshan 23Nanjing删除某行Fred Wilson 会被删除:DELETE FROM Person WHERE LastName = Wilson 结果:LastNameFirstNameAddressCityGatesBillXuanwumen 10Beijing删除所有行可以在不删

26、除表的情况下删除所有的行。这意味着表的结构、属性和索引都是完整的:DELETE FROM table_name或者:DELETE * FROM table_nameSQL高级SQL TOP 子句TOP 子句TOP 子句用于规定要返回的记录的数目。对于拥有数千条记录的大型表来说,TOP 子句是非常有用的。注释:并非所有的数据库系统都支持 TOP 子句。SQL Server 的语法:SELECT TOP number|percent column_name(s)FROM table_nameMySQL 和 Oracle 中的 SQL SELECT TOP 是等价的MySQL 语法SELECT co

27、lumn_name(s)FROM table_nameLIMIT number例子SELECT *FROM PersonsLIMIT 5Oracle 语法SELECT column_name(s)FROM table_nameWHERE ROWNUM = number例子SELECT *FROM PersonsWHERE ROWNUM = 5原始的表 (用在例子中的):Persons 表:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasC

28、hangan StreetBeijing4ObamaBarackPennsylvania AvenueWashingtonSQL TOP 实例现在,我们希望从上面的 Persons 表中选取头两条记录。我们可以使用下面的 SELECT 语句:SELECT TOP 2 * FROM Persons结果:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew YorkSQL TOP PERCENT 实例现在,我们希望从上面的 Persons 表中选取 50% 的记录。我们可以使用下面

29、的 SELECT 语句:SELECT TOP 50 PERCENT * FROM Persons结果:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew YorkSQL LIKE 操作符LIKE 操作符用于在 WHERE 子句中搜索列中的指定模式。LIKE 操作符LIKE 操作符用于在 WHERE 子句中搜索列中的指定模式。SQL LIKE 操作符语法SELECT column_name(s)FROM table_nameWHERE column_name LIKE patt

30、ern原始的表 (用在例子中的):Persons 表:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetBeijingLIKE 操作符实例例子 1现在,我们希望从上面的 Persons 表中选取居住在以 N 开场的城市里的人:我们可以使用下面的 SELECT 语句:SELECT * FROM PersonsWHERE City LIKE N%提示:% 可用于定义通配符模式中缺少的字母。结果集:IdLastName

31、FirstNameAddressCity2BushGeorgeFifth AvenueNew York例子 2接下来,我们希望从 Persons 表中选取居住在以 g 结尾的城市里的人:我们可以使用下面的 SELECT 语句:SELECT * FROM PersonsWHERE City LIKE %g结果集:IdLastNameFirstNameAddressCity3CarterThomasChangan StreetBeijing例子 3接下来,我们希望从 Persons 表中选取居住在包含 lon 的城市里的人:我们可以使用下面的 SELECT 语句:SELECT * FROM Per

32、sonsWHERE City LIKE %lon%结果集:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon例子 4通过使用 NOT 关键字,我们可以从 Persons 表中选取居住在不包含 lon 的城市里的人:我们可以使用下面的 SELECT 语句:SELECT * FROM PersonsWHERE City NOT LIKE %lon%结果集:IdLastNameFirstNameAddressCity2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetB

33、eijingSQL 通配符在搜索数据库中的数据时,您可以使用 SQL 通配符。SQL 通配符在搜索数据库中的数据时,SQL 通配符可以替代一个或多个字符。SQL 通配符必须与 LIKE 运算符一起使用。在 SQL 中,可使用以下通配符:通配符描述%替代一个或多个字符_仅替代一个字符charlist字符列中的任何单一字符charlist或者!charlist不在字符列中的任何单一字符原始的表 (用在例子中的):Persons 表:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNe

34、w York3CarterThomasChangan StreetBeijing使用 % 通配符例子 1现在,我们希望从上面的 Persons 表中选取居住在以 Ne 开场的城市里的人:我们可以使用下面的 SELECT 语句:SELECT * FROM PersonsWHERE City LIKE Ne%结果集:IdLastNameFirstNameAddressCity2BushGeorgeFifth AvenueNew York例子 2接下来,我们希望从 Persons 表中选取居住在包含 lond 的城市里的人:我们可以使用下面的 SELECT 语句:SELECT * FROM Pers

35、onsWHERE City LIKE %lond%结果集:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon使用 _ 通配符例子 1现在,我们希望从上面的 Persons 表中选取名字的第一个字符之后是 eorge 的人:我们可以使用下面的 SELECT 语句:SELECT * FROM PersonsWHERE FirstName LIKE _eorge结果集:IdLastNameFirstNameAddressCity2BushGeorgeFifth AvenueNew York例子 2接下来,我们希望从 Persons

36、表中选取的这条记录的姓氏以 C 开头,然后是一个任意字符,然后是 r,然后是任意字符,然后是 er:我们可以使用下面的 SELECT 语句:SELECT * FROM PersonsWHERE LastName LIKE C_r_er结果集:IdLastNameFirstNameAddressCity3CarterThomasChangan StreetBeijing使用 charlist 通配符例子 1现在,我们希望从上面的 Persons 表中选取居住的城市以 A 或 L 或 N 开头的人:我们可以使用下面的 SELECT 语句:SELECT * FROM PersonsWHERE Cit

37、y LIKE ALN%结果集:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York例子 2现在,我们希望从上面的 Persons 表中选取居住的城市不以 A 或 L 或 N 开头的人:我们可以使用下面的 SELECT 语句:SELECT * FROM PersonsWHERE City LIKE !ALN%结果集:IdLastNameFirstNameAddressCity3CarterThomasChangan StreetBeijingSQL IN 操作符IN 操

38、作符IN 操作符允许我们在 WHERE 子句中规定多个值。SQL IN 语法SELECT column_name(s)FROM table_nameWHERE column_name IN (value1,value2,.)原始的表 (在实例中使用:)Persons 表:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetBeijingIN 操作符实例现在,我们希望从上表中选取姓氏为 Adams 和 Carter

39、的人:我们可以使用下面的 SELECT 语句:SELECT * FROM PersonsWHERE LastName IN (Adams,Carter)结果集:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon3CarterThomasChangan StreetBeijingSQL BETWEEN 操作符BETWEEN 操作符在 WHERE 子句中使用,作用是选取介于两个值之间的数据围。BETWEEN 操作符操作符 BETWEEN . AND 会选取介于两个值之间的数据围。这些值可以是数值、文本或者日期。SQL BETWEE

40、N 语法SELECT column_name(s)FROM table_nameWHERE column_nameBETWEEN value1 AND value2原始的表 (在实例中使用:)Persons 表:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetBeijing4GatesBillXuanwumen 10BeijingBETWEEN 操作符实例如需以字母顺序显示介于 Adams包括和 Carter不

41、包括之间的人,请使用下面的 SQL:SELECT * FROM PersonsWHERE LastNameBETWEEN Adams AND Carter结果集:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York重要事项:不同的数据库对 BETWEEN.AND 操作符的处理方式是有差异的。某些数据库会列出介于 Adams 和 Carter 之间的人,但不包括 Adams 和 Carter ;某些数据库会列出介于 Adams 和 Carter 之间并包括 Adams

42、和 Carter 的人;而另一些数据库会列出介于 Adams 和 Carter 之间的人,包括 Adams ,但不包括 Carter 。所以,请检查你的数据库是如何处理 BETWEEN.AND 操作符的!实例 2如需使用上面的例子显示围之外的人,请使用 NOT 操作符:SELECT * FROM PersonsWHERE LastNameNOT BETWEEN Adams AND Carter结果集:IdLastNameFirstNameAddressCity3CarterThomasChangan StreetBeijing4GatesBillXuanwumen 10BeijingSQL A

43、lias别名通过使用 SQL,可以为列名称和表名称指定别名Alias。SQL Alias表的 SQL Alias 语法SELECT column_name(s)FROM table_nameAS alias_name列的 SQL Alias 语法SELECT column_name AS alias_nameFROM table_nameAlias 实例: 使用表名称别名假设我们有两个表分别是:Persons 和 Product_Orders。我们分别为它们指定别名 p 和 po。现在,我们希望列出 John Adams 的所有定单。我们可以使用下面的 SELECT 语句:SELECT po.

44、OrderID, p.LastName, p.FirstNameFROM Persons AS p, Product_Orders AS poWHERE p.LastName=AdamsWHERE p.FirstName=John不使用别名的 SELECT 语句:SELECT Product_Orders.OrderID, Persons.LastName, Persons.FirstNameFROM Persons, Product_OrdersWHERE Persons.LastName=HansenWHERE Persons.FirstName=Ola从上面两条 SELECT 语句您可以

45、看到,别名使查询程序更易阅读和书写。Alias 实例: 使用一个列名别名表 Persons:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetBeijingSQL:SELECT LastNameAS Family, FirstNameAS NameFROM Persons结果:FamilyNameAdamsJohnBushGeorgeCarterThomasSQL JOINSQL join 用于根据两个或多个表中

46、的列之间的关系,从这些表中查询数据。Join 和 Key有时为了得到完整的结果,我们需要从两个或更多的表中获取结果。我们就需要执行 join。数据库中的表可通过键将彼此联系起来。主键Primary Key是一个列,在这个列中的每一行的值都是唯一的。在表中,每个主键的值都是唯一的。这样做的目的是在不重复每个表中的所有数据的情况下,把表间的数据穿插捆绑在一起。请看 Persons 表:Id_PLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasCha

47、ngan StreetBeijing请注意,Id_P 列是 Persons 表中的的主键。这意味着没有两行能够拥有一样的 Id_P。即使两个人的完全一样,Id_P 也可以区分他们。接下来请看 Orders 表:Id_OOrderNoId_P177895324467833224561424562153476465请注意,Id_O 列是 Orders 表中的的主键,同时,Orders 表中的 Id_P 列用于引用 Persons 表中的人,而无需使用他们确实切。请留意,Id_P 列把上面的两个表联系了起来。引用两个表我们可以通过引用两个表的方式,从两个表中获取数据:谁订购了产品,并且他们订购了什么

48、产品?SELECT Persons.LastName, Persons.FirstName, Orders.OrderNoFROM Persons, OrdersWHERE Persons.Id_P = Orders.Id_P 结果集:LastNameFirstNameOrderNoAdamsJohn22456AdamsJohn24562CarterThomas77895CarterThomas44678SQL JOIN - 使用 Join除了上面的方法,我们也可以使用关键词 JOIN 来从两个表中获取数据。如果我们希望列出所有人的定购,可以使用下面的 SELECT 语句:SELECT Per

49、sons.LastName, Persons.FirstName, Orders.OrderNoFROM PersonsINNER JOIN OrdersON Persons.Id_P = Orders.Id_PORDER BY Persons.LastName结果集:LastNameFirstNameOrderNoAdamsJohn22456AdamsJohn24562CarterThomas77895CarterThomas44678不同的 SQL JOIN除了我们在上面的例子中使用的 INNER JOIN连接,我们还可以其他几种连接。下面列出了您可以使用的 JOIN 类型,以与它们之间的

50、差异。 JOIN: 如果表中有至少一个匹配,那么返回行 LEFT JOIN: 即使右表中没有匹配,也从左表返回所有的行 RIGHT JOIN: 即使左表中没有匹配,也从右表返回所有的行 FULL JOIN: 只要其中一个表中存在匹配,就返回行 SQL INNER JOIN 关键字SQL INNER JOIN 关键字在表中存在至少一个匹配时,INNER JOIN 关键字返回行。INNER JOIN 关键字语法SELECT column_name(s)FROM table_name1INNER JOIN table_name2 ON table_name1.column_name=table_na

51、me2.column_name注释:INNER JOIN 与 JOIN 是一样的。原始的表 (用在例子中的):Persons 表:Id_PLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetBeijingOrders 表:Id_OOrderNoId_P177895324467833224561424562153476465连接INNER JOIN实例现在,我们希望列出所有人的定购。您可以使用下面的 SELECT 语句:

52、SELECT Persons.LastName, Persons.FirstName, Orders.OrderNoFROM PersonsINNER JOIN OrdersON Persons.Id_P=Orders.Id_PORDER BY Persons.LastName结果集:LastNameFirstNameOrderNoAdamsJohn22456AdamsJohn24562CarterThomas77895CarterThomas44678INNER JOIN 关键字在表中存在至少一个匹配时返回行。如果 Persons 中的行在 Orders 中没有匹配,就不会列出这些行。SQL

53、 LEFT JOIN 关键字SQL LEFT JOIN 关键字LEFT JOIN 关键字会从左表 (table_name1) 那里返回所有的行,即使在右表 (table_name2) 中没有匹配的行。LEFT JOIN 关键字语法SELECT column_name(s)FROM table_name1LEFT JOIN table_name2 ON table_name1.column_name=table_name2.column_name注释:在某些数据库中, LEFT JOIN 称为 LEFT OUTER JOIN。原始的表 (用在例子中的):Persons 表:Id_PLastNam

54、eFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetBeijingOrders 表:Id_OOrderNoId_P177895324467833224561424562153476465左连接LEFT JOIN实例现在,我们希望列出所有的人,以与他们的定购 - 如果有的话。您可以使用下面的 SELECT 语句:SELECT Persons.LastName, Persons.FirstName, Orders.OrderNoFROM

55、 PersonsLEFT JOIN OrdersON Persons.Id_P=Orders.Id_PORDER BY Persons.LastName结果集:LastNameFirstNameOrderNoAdamsJohn22456AdamsJohn24562CarterThomas77895CarterThomas44678BushGeorgeLEFT JOIN 关键字会从左表 (Persons) 那里返回所有的行,即使在右表 (Orders) 中没有匹配的行。SQL RIGHT JOIN 关键字SQL RIGHT JOIN 关键字RIGHT JOIN 关键字会右表 (table_name2) 那里返回所有的行,即使在左表 (table_name1) 中没有匹配的行。RIGHT JOIN 关键字语法SELECT column_name(s)FROM table_name1RIGHT JOIN table_name2 ON table_name1.column_name=table_name2.column_name注释:在某些数据库中, RIGHT JOIN 称为 RIGHT OUTER JOIN。原始的表 (用在例子中的):Persons 表:

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!