




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、SQL教程? Next PageSQL是用于访问和处理数据库的标准的计算机语言。Oracle, Sybase,在本教程中,您将学到如何使用 SQL访问和处理数据系统中的数据,这类数据库包括:SQL Server, DB2, Access 等等。开始学习SQL !注:本教程中出现的姓名、地址等信息仅供教学,与实际情况无关。SQL测验在W3School 测试你的SQL技能!开始SQL测验!SQL简介P revious P ageNext PageSQL是用于访问和处理数据库的标准的计算机语言。什么是SQL ?SQL指结构化查询语言SQL使我们有能力访问数据库SQL是一种ANSI的标准计算机语言编者
2、注:ANSI,美国国家标准化组织SQL能做什么?SQL面向数据库执行查询SQL可从数据库取回数据SQL可在数据库中插入新的纪录SQL可更新数据库中的数据SQL可从数据库删除记录SQL可创建新数据库SQL可在数据库中创建新表SQL可在数据库中创建存储过程SQL可在数据库中创建视图SQL可以设置表、存储过程和视图的权限SQL是一种标准-但是SQL是一门ANSI的标准计算机语言,用来访问和操作数据库系统。 的数据。SQL可与数据库程序协同工作,比如MS AccessSybase以及其他数据库系统。SQL语句用于取回和更新数据库中、DB2、Informix 、MS SQL Server、Oracle、
3、不幸地是,存在着很多不同版本的 同地来支持一些主要的关键词(比如SQL语言,但是为了与SELECT、UP DATE、ANSI标准相兼容,它们必须以相似的方式共DELETE、INSERT、WHERE 等等)。注释:除了 SQL标准之外,大部分SQL数据库程序都拥有它们自己的私有扩展!在您的网站中使用 SQL要创建发布数据库中数据的网站,您需要以下要素:RDBMS 数据库程序(比如 MS Access, SQL Server, MySQL ) 服务器端脚本语言(比如 PHP或ASP)SQLHTML/CSSRDBMSRDBMS指的是关系型数据库管理系统。RDBMSMySQL是SQL的基础,同样也是所
4、有现代数据库系统的基础,比如MS SQL Server, IBM DB2, Oracle,以及 Microsoft Access 。RDBMS中的数据存储在被称为表(tables )的数据库对象中。表是相关的数据项的集合,它由列和行组成。SQL语法P revious P ageNext Page数据库表一个数据库通常包含一个或多个表。每个表由一个名字标识(例如“客户”或者“订单”)。表包含带有数据的记录(行)。下面的例子是一个名为"P ersons"的表:IdLastNameFirstNameAddressCityAdamsJohnOxford StreetLondonBu
5、shGeorgeFifth AvenueNew YorkCarterThomasChangan StreetBeijing上面的表包含三条记录(每一条对应一个人)和五个列(Id、姓、名、地址和城市)。SQL语句您需要在数据库上执行的大部分工作都由SQL语句完成。下面的语句从表中选取LastName 列的数据:SELECT LastName FROM P ersons结果集类似这样:LastNameAdamsBushCarter在本教程中,我们将为您讲解各种不同的SQL语句。重要事项一定要记住,SQL对大小写不敏感!SQL语句后面的分号?某些数据库系统要求在每条 SQL命令的末端使用分号。在我们
6、的教程中不使用分号。分号是在数据库系统中分隔每条SQL语句的标准方法,这样就可以在对服务器的相同请求中执行一条以上的语句。如果您使用的是 MS Access和SQL Server 2000 ,则不必在每条 SQL语句之后使用分号,不过某些数据库软件要求必须使用分号。SQL DML 和 DDL可以把SQL分为两个部分:数据操作语言 (DML)和数据定义语言(DDL)。SQL (结构化查询语言)是用于执行查询的语法。但是SQL语言也包含用于更新、插入和删除记录的语法。查询和更新指令构成了 SQL的DML部分:SELECT -从数据库表中获取数据UP DATE -更新数据库表中的数据DELETE -
7、从数据库表中删除数据INSERT INTO -向数据库表中插入数据SQL的数据定义语言(DDL)的链接,以及施加表间的约束。部分使我们有能力创建或删除表格。我们也可以定义索引(键),规定表之间SQL中最重要的 DDL语句:CREATE DATABASE-创建新数据库ALTER DATABASE-修改数据库CREATE TABLE -仓U建新表ALTER TABLE -变更(改变)数据库表DROP TABLE -删除表CREATE INDEX -创建索引(搜索键)DROP INDEX -删除索弓ISQL SELECT 语句?P revious P age? Next Page本章讲解SELECT
8、和SELECT *语句。SQL SELECT 语句SELECT语句用于从表中选取数据。结果被存储在一个结果表中(称为结果集)SQL SELECT 语法SELECT列名称FROM表名称以及:SELECT * FROM 表名称注释:SQL语句对大小写不敏感。 SELECT等效于select。SQL SELECT 实例如需获取名为"LastName" 和"FirstName" 的列的内容(从名为"Persons"的数据库表),请使用类似 这样的SELECT语句:SELECT LastName,FirstName FROM Persons&q
9、uot;P ersons"表:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetBeijing结果:LastNameFirstNameAdamsJohnBushGeorgeCarterThomasSQL SELECT *实例现在我们希望从"P ersons" 表中选取所有的列。请使用符号*取代列的名称,就像这样:SELECT * FROM P ersons提示:星号(*)是选取所有列
10、的快捷方式。结果:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetBeijing在结果集(result-set)中导航由SQL查询程序获得的结果被存放在一个结果集中。大多数数据库软件系统都允许使用编程函数在结果集中进行导航,比如:Move-To-First-Record 、Get-Record-Content 、Move-To-Next-Record 等等。ADO教类似这些编程函数不在本教程讲解之列。如需学习通
11、过函数调用访问数据的知识,请访问我们的 程和PHP教程。SQL SELECT DISTINCT 语句P revious P ageNext Page本章讲解SELECT DISTINCT 语句。SQL SELECT DISTINCT 语句distinct )的值。在表中,可能会包含重复值。这并不成问题,不过,有时您也许希望仅仅列出不同(关键词 DISTINCT用于返回唯一不同的值。语法:SELECT DISTINCT列名称FROM表名称使用 DISTINCT关键词如果要从"Com pany"列中选取所有的值,我们需要使用SELECT语句:SELECT Comp any FR
12、OM Orders"Orders"表:Comp anyOrderNumberIBM3532W3School2356App le4698W3School6953结果:Comp anyIBMW3SchoolAppleW3School请注意,在结果集中,W3School被列出了两次。如需从Company" 列中仅选取唯一不同的值,我们需要使用SELECT DISTINCT语句:SELECT DISTINCT Company FROM Orders结果:Comp anyIBMW3SchoolApple现在,在结果集中,"W3School" 仅被列出了一
13、次。SQL SELECT DISTINCT 语句P revious P age? Next Page本章讲解SELECT DISTINCT 语句。SQL SELECT DISTINCT 语句distinct )的值。在表中,可能会包含重复值。这并不成问题,不过,有时您也许希望仅仅列出不同(关键词 DISTINCT用于返回唯一不同的值。语法:SELECT DISTINCT列名称FROM表名称使用 DISTINCT关键词如果要从"Com pany"列中选取所有的值,我们需要使用SELECT语句:SELECT Comp any FROM Orders"Orders&qu
14、ot;表:Comp anyOrderNumberIBM3532W3School2356App le4698W3School6953结果:Comp anyIBMW3SchoolAppleW3School请注意,在结果集中,W3School被列出了两次。如需从Comp any"列中仅选取唯一不同的值,我们需要使用SELECT DISTINCT语句:SELECT DISTINCTComp any FROM Orders结果:Comp anyIBMW3SchoolApple现在,在结果集中,"W3School"仅被列出了一次。SQL AND & OR运算符? P
15、revious P age? Next PageAND和OR运算符用于基于一个以上的条件对记录进行过滤。AND 和OR运算符AND 和OR可在WHERE子语句中把两个或多个条件结合起来。如果第一个条件和第二个条件都成立,则AND运算符显示一条记录。如果第一个条件和第二个条件中只要有一个成立,则OR运算符显示一条记录。原始的表(用在例子中的):LastNameFirstNameAddressCityAdamsJohnOxford StreetLondonBushGeorgeFifth AvenueNew YorkCarterThomasChangan StreetBeijingCarterWil
16、liamXuanwumen 10BeijingAND运算符实例使用AND来显示所有姓为"Carter" 并且名为 "Thomas" 的人:AND LastName='Carter'SELECT * FROM P ersons WHERE FirstName='Thomas'结果:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingOR运算符实例使用OR来显示所有姓为"Carter" 或者名为"Thomas" 的人:
17、OR lastname='Carter'SELECT * FROM P ersons WHERE firstname='Thomas'结果:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingCarterWilliamXuanwumen 10Beijing结合AND和OR运算符我们也可以把AND和OR结合起来(使用圆括号来组成复杂的表达式)SELECT * FROM P ersons WHERE(FirstName='Thomas'OR FirstName='Willi
18、am' )AND LastName='Carter'结果:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingCarterWilliamXuanwumen 10BeijingP revious P age? Next PageAND和OR运算符用于基于一个以上的条件对记录进行过滤。AND 和OR运算符AND 和OR可在WHERE子语句中把两个或多个条件结合起来。OR运算符显示一条记录。如果第一个条件和第二个条件都成立,则AND运算符显示一条记录。原始的表(用在例子中的):LastNameFirstNa
19、meAddressCityAdamsJohnOxford StreetLondonBushGeorgeFifth AvenueNew YorkCarterThomasChangan StreetBeijingCarterWilliamXuanwumen 10BeijingAND运算符实例使用AND来显示所有姓为"Carter"并且名为"Thomas"的人:如果第一个条件和第二个条件中只要有一个成立,则AND LastName='Carter'SELECT * FROM P ersons WHERE FirstName='Thoma
20、s'结果:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingOR运算符实例使用OR来显示所有姓为"Carter" 或者名为"Thomas" 的人:OR lastname='Carter'SELECT * FROM P ersons WHERE firstname='Thomas'结果:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingCarterWilliamXuanwum
21、en 10Beijing结合AND和OR运算符我们也可以把AND和OR结合起来(使用圆括号来组成复杂的表达式)SELECT * FROM P ersons WHERE(FirstName='Thomas'OR FirstName='William' )AND LastName='Carter'_结果:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingCarterWilliamXuanwumen 10BeijingSQL INSERT INTO语句P revious P age
22、Next PageINSERT INTO 语句INSERT INTO语句用于向表格中插入新的行。语法INSERT INTO 表名称 VALUES (值 1,值2,.)我们也可以指定所要插入数据的列:INSERT INTO table_name (列1,列2,.) VALUES (值 1,值2,.)插入新的行"P ersons"表:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingSQL语句:INSERT INTO P ersons VALUES ('Gates', 'Bill
23、39;, 'Xuanwumen 10', 'Beijing')结果:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingGatesBillXuanwumen 10Beijing在指定的列中插入数据"P ersons"表:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingGatesBillXuanwumen 10BeijingSQL语句:INSERT INTO Persons (LastName, Add
24、ress) VALUES ('Wilson', 'Cha mp s-Elysees')SQL UP DATE语句结果:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingGatesBillXuanwumen 10BeijingWilsonChamp s-ElyseesP revious P ageNext PageUp date语句Up date语句用于修改表中的数据。语法:UP DATE表名称SET列名称=新值WHERE列名称=某值Person:LastNameFirstNameAddres
25、sCityGatesBillXuanwumen 10BeijingWilsonChamp s-Elysees更新某一行中的一个列我们为 lastname 是"Wilson"的人添加 firstname :UP DATE Person SET FirstName = 'Fred' WHERE LastName = 'Wilson'结果:LastNameFirstNameAddressCityGatesBillXuanwumen 10BeijingWilsonFredChamp s-Elysees更新某一行中的若干列我们会修改地址(address
26、),并添加城市名称(city):UP DATE P erson SET Address='Zhongshan 23', City = 'Nanjing'WHERE LastName = 'Wilson'结果:LastNameFirstNameAddressCityGatesBillXuanwumen 10BeijingWilsonFredZhongshan 23NanjingSQL DELETE语句P revious P ageNext PageDELETE语句DELETE语句用于删除表中的行。语法DELETE FROM表名称 WHERE列名称=
27、值Person:LastNameFirstNameAddressCityGatesBillXuanwumen 10BeijingWilsonFredZhongshan 23Nanjing删除某行"Fred Wilson"会被删除:DELETE FROM P erson WHERELastName = 'Wilson'结果:LastNameFirstNameAddressCityGatesBillXuanwumen 10Beijing删除所有行属性和索引都是完整的:可以在不删除表的情况下删除所有的行。这意味着表的结构、DELETE FROM table nam
28、e或者:DELETE * FROM table nameSQL TOP子句P revious P ageNext PageTOP子句TOP子句用于规定要返回的记录的数目。对于拥有数千条记录的大型表来说,TOP子句是非常有用的。注释:并非所有的数据库系统都支持TOP子句。SQL Server 的语法:SELECT TOP number percent column_name(s)FROM table nameMySQL 和 Oracle 中的 SQL SELECT TOP 是等价的MySQL语法SELECT column_name(s)FROM table nameLIMIT number例子S
29、ELECT *FROM P ersonsLIMIT 5Oracle 语法SELECT column_name(s)FROM table nameWHERE ROWNUM <= number例子SELECT *FROM PersonsWHERE ROWNUM <= 5原始的表(用在例子中的):Persons 表:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetBeijing4ObamaBarackP
30、ennsylvania AvenueWashingtonSQL TOP 实例现在,我们希望从上面的"P ersons"表中选取头两条记录。我们可以使用下面的 SELECT语句:SELECT TOP 2 * FROM Persons结果:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew YorkSQL TOP P ERCENT实例现在,我们希望从上面的"P ersons"表中选取50%的记录。我们可以使用下面的 SELECT语句:SEL
31、ECT TOP 50 PERCENT * FROM PersonsSQL LIKE操作符结果:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew YorkP revious P ageNext PageLIKE操作符用于在 WHERE子句中搜索列中的指定模式。LIKE操作符LIKE操作符用于在 WHERE子句中搜索列中的指定模式。SQL 口KE操作符语法SELECT column_name(s)FROM table nameWHERE column_name LIKE p a
32、ttern原始的表(用在例子中的):LIKE操作符实例Persons 表:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetBeijing例子1现在,我们希望从上面的"P ersons"表中选取居住在以"N"开始的城市里的人:我们可以使用下面的 SELECT语句:SELECT * FROM P ersonsWHERE City LIKE 'N%'提示:&qu
33、ot;"可用于定义通配符(模式中缺少的字母)结果集:IdLastNameFirstNameAddressCityBushGeorgeFifth AvenueNew York例子接下来,我们希望从"P ersons" 表中选取居住在以"g"结尾的城市里的人:我们可以使用下面的 SELECT语句:SELECT * FROM P ersonsWHERE City LIKE '%g'结果集:IdLastNameFirstNameAddressCityCarterThomasChangan StreetBeijing例子接下来,我们希望从
34、"P ersons" 表中选取居住在包含"Ion"的城市里的人:我们可以使用下面的SELECT 语句:SELECT * FROM P ersonsWHERE City LIKE '%lon%'结果集:IdLastNameFirstNameAddressCityAdamsJohnOxford StreetLondon例子通过使用NOT关键字,我们可以从"Persons" 表中选取居住在不包含"Ion"的城市里的人:我们可以使用下面的 SELECT语句:SELECT * FROM P ersonsWHE
35、RE City NOT l_l KE '%lon%'结果集:IdLastNameFirstNameAddressCity2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetBeijingSQL通配符P revious P age? Next Page在搜索数据库中的数据时,您可以使用SQL通配符。SQL通配符在搜索数据库中的数据时,SQL通配符可以替代一个或多个字符。SQL通配符必须与 LIKE运算符一起使用。在SQL中,可使用以下通配符:描述通配符替代一个或多个字符仅替代一个字符charlist字符列中的任何单一
36、字符Fcharlist 或者不在字符列中的任何单一字符!charlist原始的表(用在例子中的):Persons 表:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew YorkCarterThomasChangan StreetBeijing使用%通配符例子现在,我们希望从上面的"P ersons"表中选取居住在以"Ne"开始的城市里的人:我们可以使用下面的 SELECT语句:SELECT * FROM P ersonsWHERE C
37、ity LIKE 'Ne%'结果集:IdLastNameFirstNameAddressCityBushGeorgeFifth AvenueNew York例子接下来,我们希望从"P ersons" 表中选取居住在包含"lond"的城市里的人:我们可以使用下面的SELECT 语句:SELECT * FROM P ersonsWHERE City LIKE '%lond%'结果集:IdLastNameFirstNameAddressCityAdamsJohnOxford StreetLondon使用通配符例子现在,我们希望从
38、上面的"P ersons"表中选取名字的第一个字符之后是"eorge"的人:WHERE FirstName LIKE '_eorge'结果集:我们可以使用下面的 SELECT语句:SELECT * FROM P ersonsIdLastNameFirstNameAddressCityBushGeorgeFifth AvenueNew York例子我们可以使用下面的 SELECT语句:SELECT * FROM P ersons"P ersons"表中选取的这条记录的姓氏以"C"开头,然后是一个任意字
39、符,然后是接下来,我们希望从"r",然后是任意字符,然后是 "er"我们可以使用下面的 SELECT语句:SELECT * FROM P ersonsWHERE LastName LIKE 'C r er'结果集:IdLastNameFirstNameAddressCityCarterThomasChangan StreetBeijing使用charlist通配符例子现在,我们希望从上面的"P ersons"表中选取居住的城市以"A"或"L"或"N"开头的人:
40、我们可以使用下面的 SELECT语句:SELECT * FROM P ersonsWHERE City LIKE 'ALN%'IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York例子2现在,我们希望从上面的"P ersons"表中选取居住的城市不以"A"或"结果集:L"或"N"开头的人:WHERE City LIKE '!ALN%'结果集:IdLastNam
41、eFirstNameAddressCityCarterThomasChangan StreetBeijingSQL IN操作符P revious P ageNext PageIN操作符IN操作符允许我们在 WHERE子句中规定多个值。SQL IN语法SELECT column_name(s)FROM table nameWHERE column_name IN (value1,value2,.)原始的表(在实例中使用:)IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew Yo
42、rk3CarterThomasChangan StreetBeijingPersons 表:IN操作符实例现在,我们希望从上表中选取姓氏为Adams 和 Carter 的人:我们可以使用下面的 SELECT语句:SELECT * FROM P ersonsWHERE LastName IN ('Adams','Carter')结果集:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon3CarterThomasChangan StreetBeijingSQL BETWEEN 操作符P reviou
43、s P ageNext PageBETWEEN操作符在WHERE子句中使用,作用是选取介于两个值之间的数据范围。BETWEEN操作符SELECT column_name(s)FROM table name操作符BETWEEN . AND 会选取介于两个值之间的数据范围。这些值可以是数值、文本或者日期。SQL BETWEEN 语法WHERE column nameBETWEEN value1 AND value2原始的表(在实例中使用:)Persons 表:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorge
44、Fifth AvenueNew York3CarterThomasChangan StreetBeijing4GatesBillXuanwumen 10BeijingBETWEEN 操作符实例如需以字母顺序显示介于"Adams"(包括)和"Carter"(不包括)之间的人,请使用下面的 SQL :SELECT * FROM P ersonsSELECT * FROM P ersonsWHERE LastNameBETWEEN 'Adams'AND 'Carter'结果集:IdLastNameFirstNameAddress
45、City1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York重要事项:不同的数据库对 BETWEENAND 操作符的处理方式是有差异的。某些数据库会列出介于和"Carter" 之间并包括"Adams""Adams" 和"Carter" 之间的人,但不包括"Adams" 和"Carter"某些数据库会列出介于"Adams"和"Carter" 的人;而另一些数据库会列出介于
46、"Adams" 和"Carter" 之间的人,包括 "Adams",但不包括 "Carter"。所以,请检查你的数据库是如何处理BETWEEN.AND 操作符的!实例2如需使用上面的例子显示范围之外的人,请使用NOT操作符:WHERE LastNameNOT BETWEEN 'Adams' AND 'Carter'结果集:IdLastNameFirstNameAddressCity3CarterThomasChangan StreetBeijing4GatesBillXuanwume
47、n 10BeijingSQL JOINP revious P age? Next PageSQL join用于根据两个或多个表中的列之间的关系,从这些表中查询数据。Join 和 Keyjoin 。有时为了得到完整的结果,我们需要从两个或更多的表中获取结果。我们就需要执行数据库中的表可通过键将彼此联系起来。主键( 唯一的。在表中,每个主键的值都是唯一的。 表间的数据交叉捆绑在一起。Primary Key )是一个列,在这个列中的每一行的值都是 这样做的目的是在不重复每个表中的所有数据的情况下,把请注意,名完全相同,Id_P也可以区分他们。"Id P"列是Persons表中的的
48、主键。这意味着没有两行能够拥有相同的Id_P。即使两个人的姓接下来请看"Orders"表:Id OOrderNoId P77895446782245624562请看"P ersons"表:ld_PLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetBeijing6534764请注意,"Id_O"列是Orders 表中的的主键,同时,"Orders&q
49、uot; 表中的"Id_P"列用于引用 "Persons" 表 中的人,而无需使用他们的确切姓名。请留意,"ld_ P"列把上面的两个表联系了起来。引用两个表我们可以通过引用两个表的方式,从两个表中获取数据: 谁订购了产品,并且他们订购了什么产品?SELECT P ersons.LastName, P ersons.FirstName, Orders.OrderNoFROM P ersons, OrdersWHERE Persons.Id P = Orders.ld PSQL JOIN -使用 Join结果集:LastNameFirs
50、tNameOrderNoAdamsJohn22456AdamsJohn24562CarterThomas77895CarterThomas44678除了上面的方法,我们也可以使用关键词JOIN来从两个表中获取数据。如果我们希望列出所有人的定购,可以使用下面的SELECT 语句:SELECT Persons.LastName, Persons.FirstName, Orders.OrderNoFROM P ersonsINNER JOIN OrdersON Persons.Id P = Orders.ld PORDER BY P ersons.LastName结果集:LastNameFirstN
51、ameOrderNoAdamsJohn22456AdamsJohn24562CarterThomas77895CarterThomas44678不同的SQL JOIN除了我们在上面的例子中使用的INNER JOIN (内连接),我们还可以使用其他几种连接。下面列出了您可以使用的JOIN类型,以及它们之间的差异。JOIN:如果表中有至少一个匹配,则返回行LEFT JOIN:即使右表中没有匹配,也从左表返回所有的行RIGHT JOIN:即使左表中没有匹配,也从右表返回所有的行FULL JOIN:只要其中一个表中存在匹配,就返回行SQL INNER JOIN关键字在表中存在至少一个匹配时,INNER JOIN 关键字返回行。INNER JOIN 关键字语法SELECT column_name(s)FROM table name1INNER JOIN table name2ON table name1.column name=table name2.column name注释:INNER JOIN 与JOIN是相同的。原始的表(用在例子中的):"P ersons"表:ld_PLastNameFirstNameA
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025-2030同步测速发电机行业市场现状供需分析及投资评估规划分析研究报告
- 2025-2030台式RFID和条形码打印机行业市场现状供需分析及重点企业投资评估规划分析研究报告
- 2025-2030口腔医疗器械行业市场发展分析及发展前景与投资机会研究报告
- 2025-2030医疗计费外包行业市场现状供需分析及投资评估规划分析研究报告
- 2025-2030化纤纱市场发展分析及行业投资战略研究报告
- 2025-2030动物蛋白饲料行业发展分析及发展趋势与投资前景预测研究报告
- 2025-2030制霉素市场行业市场现状供需分析及投资评估规划分析研究报告
- 2025-2030冠状动脉搭桥术行业市场现状供需分析及投资评估规划分析研究报告
- 2025-2030内燃机减震器行业市场调研分析及发展趋势与投资前景研究报告
- 2025-2030全球及中国物理安全软件行业市场现状供需分析及投资评估规划分析研究报告
- 某地产项目红线广告围挡工程投标文件
- 企业职工代表任命协议书
- 山东司法警官职业学院教师招聘考试真题2022
- 地下管线测绘及数据处理
- 附件1:中国联通动环监控系统B接口技术规范(V3.0)
- 卫生院B超、心电图室危急值报告制度及流程
- 医疗器械经营公司-年度培训计划表
- 校园青年志愿者培训(服务礼仪讲解)
- 教练员教学质量信誉考核表
- 普通高中学生综合素质评价档案
- 酒店工程部维修工作单
评论
0/150
提交评论