《SQL教学大全.doc》由会员分享,可在线阅读,更多相关《SQL教学大全.doc(99页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、数据库表一个数据库通常包含一个或多个表。每个表由一个名字标识(例如“客户”或者“订单”)。表包含带有数据的记录(行)。下面的例子是一个名为 Persons 的表:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York 3CarterThomasChangan StreetBeijing上面的表包含三条记录(每一条对应一个人)和五个列(Id、姓、名、地址和城市)。SQL 语句您需要在数据库上执行的大部分工作都由 SQL 语句完成。下面的语句从表中选取 LastName 列
2、的数据:SELECT LastName FROM Persons结果集类似这样:LastNameAdamsBushCarter在本教程中,我们将为您讲解各种不同的 SQL 语句。重要事项一定要记住,SQL 对大小写不敏感!SQL 语句后面的分号?某些数据库系统要求在每条 SQL 命令的末端使用分号。在我们的教程中不使用分号。分号是在数据库系统中分隔每条 SQL 语句的标准方法,这样就可以在对服务器的相同请求中执行一条以上的语句。如果您使用的是 MS Access 和 SQL Server 2000,则不必在每条 SQL 语句之后使用分号,不过某些数据库软件要求必须使用分号。SQL DML 和
3、DDL可以把 SQL 分为两个部分:数据操作语言 (DML) 和 数据定义语言 (DDL)。 SQL (结构化查询语言)是用于执行查询的语法。但是 SQL 语言也包含用于更新、插入和删除记录的语法。查询和更新指令构成了 SQL 的 DML 部分: SELECT - 从数据库表中获取数据 UPDATE - 更新数据库表中的数据 DELETE - 从数据库表中删除数据 INSERT INTO - 向数据库表中插入数据 SQL 的数据定义语言 (DDL) 部分使我们有能力创建或删除表格。我们也可以定义索引(键),规定表之间的链接,以及施加表间的约束。SQL 中最重要的 DDL 语句: CREATE
4、DATABASE - 创建新数据库 ALTER DATABASE - 修改数据库 CREATE TABLE - 创建新表 ALTER TABLE - 变更(改变)数据库表 DROP TABLE - 删除表 CREATE INDEX - 创建索引(搜索键) DROP INDEX - 删除索引 本章讲解 SELECT 和 SELECT * 语句。SQL SELECT 语句SELECT 语句用于从表中选取数据。结果被存储在一个结果表中(称为结果集)。SQL SELECT 语法SELECT 列名称 FROM 表名称以及:SELECT * FROM 表名称注释:SQL 语句对大小写不敏感。SELECT
5、等效于 select。SQL SELECT 实例如需获取名为 LastName 和 FirstName 的列的内容(从名为 Persons 的数据库表),请使用类似这样的 SELECT 语句:SELECT LastName,FirstName FROM PersonsPersons 表:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York 3CarterThomasChangan StreetBeijing结果:LastNameFirstNameAdamsJohnBu
6、shGeorgeCarterThomasSQL SELECT * 实例现在我们希望从 Persons 表中选取所有的列。请使用符号 * 取代列的名称,就像这样:SELECT * FROM Persons提示:星号(*)是选取所有列的快捷方式。结果:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York 3CarterThomasChangan StreetBeijing在结果集(result-set)中导航由 SQL 查询程序获得的结果被存放在一个结果集中。大多数数据库
7、软件系统都允许使用编程函数在结果集中进行导航,比如:Move-To-First-Record、Get-Record-Content、Move-To-Next-Record 等等。类似这些编程函数不在本教程讲解之列。如需学习通过函数调用访问数据的知识,请访问我们的 ADO 教程 和 PHP 教程。本章讲解 SELECT DISTINCT 语句。SQL SELECT DISTINCT 语句在表中,可能会包含重复值。这并不成问题,不过,有时您也许希望仅仅列出不同(distinct)的值。关键词 DISTINCT 用于返回唯一不同的值。语法:SELECT DISTINCT 列名称 FROM 表名称使用
8、 DISTINCT 关键词如果要从 Company 列中选取所有的值,我们需要使用 SELECT 语句:SELECT Company FROM OrdersOrders表:CompanyOrderNumberIBM3532W3School2356Apple4698W3School6953结果:CompanyIBMW3SchoolAppleW3School请注意,在结果集中,W3School 被列出了两次。如需从 Company 列中仅选取唯一不同的值,我们需要使用 SELECT DISTINCT 语句:SELECT DISTINCT Company FROM Orders 结果:Company
9、IBMW3SchoolApple现在,在结果集中,W3School 仅被列出了一次。WHERE 子句用于规定选择的标准。WHERE 子句如需有条件地从表中选取数据,可将 WHERE 子句添加到 SELECT 语句。语法SELECT 列名称 FROM 表名称 WHERE 列 运算符 值下面的运算符可在 WHERE 子句中使用:操作符描述=等于不等于大于=大于等于=小于等于BETWEEN在某个范围内LIKE搜索某种模式注释:在某些版本的 SQL 中,操作符 可以写为 !=。使用 WHERE 子句如果只希望选取居住在城市 Beijing 中的人,我们需要向 SELECT 语句添加 WHERE 子句:
10、SELECT * FROM Persons WHERE City=BeijingPersons 表LastNameFirstNameAddressCityYearAdamsJohnOxford StreetLondon1970BushGeorgeFifth AvenueNew York 1975CarterThomasChangan StreetBeijing1980GatesBillXuanwumen 10Beijing1985结果:LastNameFirstNameAddressCityYearCarterThomasChangan StreetBeijing1980GatesBillXu
11、anwumen 10Beijing1985引号的使用请注意,我们在例子中的条件值周围使用的是单引号。SQL 使用单引号来环绕文本值(大部分数据库系统也接受双引号)。如果是数值,请不要使用引号。文本值:这是正确的:SELECT * FROM Persons WHERE FirstName=Bush这是错误的:SELECT * FROM Persons WHERE FirstName=Bush数值:这是正确的:SELECT * FROM Persons WHERE Year1965这是错误的:SELECT * FROM Persons WHERE Year1965AND 和 OR 运算符用于基于一
12、个以上的条件对记录进行过滤。AND 和 OR 运算符AND 和 OR 可在 WHERE 子语句中把两个或多个条件结合起来。如果第一个条件和第二个条件都成立,则 AND 运算符显示一条记录。如果第一个条件和第二个条件中只要有一个成立,则 OR 运算符显示一条记录。原始的表 (用在例子中的):LastNameFirstNameAddressCityAdamsJohnOxford StreetLondonBushGeorgeFifth AvenueNew York CarterThomasChangan StreetBeijingCarterWilliamXuanwumen 10BeijingAND
13、 运算符实例使用 AND 来显示所有姓为 Carter 并且名为 Thomas 的人:SELECT * FROM Persons WHERE FirstName=Thomas AND LastName=Carter结果:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingOR 运算符实例使用 OR 来显示所有姓为 Carter 或者名为 Thomas 的人:SELECT * FROM Persons WHERE firstname=Thomas OR lastname=Carter结果:LastNameFirstNameAd
14、dressCityCarterThomasChangan StreetBeijingCarterWilliamXuanwumen 10Beijing结合 AND 和 OR 运算符我们也可以把 AND 和 OR 结合起来(使用圆括号来组成复杂的表达式):SELECT * FROM Persons WHERE (FirstName=Thomas OR FirstName=William)AND LastName=Carter结果:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingCarterWilliamXuanwumen 1
15、0BeijingORDER BY 语句用于对结果集进行排序。ORDER BY 语句ORDER BY 语句用于根据指定的列对结果集进行排序。ORDER BY 语句默认按照升序对记录进行排序。如果您希望按照降序对记录进行排序,可以使用 DESC 关键字。原始的表 (用在例子中的):Orders 表:CompanyOrderNumberIBM3532W3School2356Apple4698W3School6953实例 1以字母顺序显示公司名称:SELECT Company, OrderNumber FROM Orders ORDER BY Company结果:CompanyOrderNumberA
16、pple4698IBM3532W3School6953W3School2356实例 2以字母顺序显示公司名称(Company),并以数字顺序显示顺序号(OrderNumber):SELECT Company, OrderNumber FROM Orders ORDER BY Company, OrderNumber结果:CompanyOrderNumberApple4698IBM3532W3School2356W3School6953实例 3以逆字母顺序显示公司名称:SELECT Company, OrderNumber FROM Orders ORDER BY Company DESC结果:
17、CompanyOrderNumberW3School6953W3School2356IBM3532Apple4698实例 4以逆字母顺序显示公司名称,并以数字顺序显示顺序号:SELECT Company, OrderNumber FROM Orders ORDER BY Company DESC, OrderNumber ASC结果:CompanyOrderNumberW3School2356W3School6953IBM3532Apple4698注意:在以上的结果中有两个相等的公司名称 (W3School)。只有这一次,在第一列中有相同的值时,第二列是以升序排列的。如果第一列中有些值为 nu
18、lls 时,情况也是这样的。INSERT INTO 语句INSERT INTO 语句用于向表格中插入新的行。语法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, Beijin
19、g)结果:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingGatesBillXuanwumen 10Beijing在指定的列中插入数据Persons 表:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingGatesBillXuanwumen 10BeijingSQL 语句:INSERT INTO Persons (LastName, Address) VALUES (Wilson, Champs-Elysees)结果:LastNameFirstNam
20、eAddressCityCarterThomasChangan StreetBeijingGatesBillXuanwumen 10BeijingWilsonChamps-ElyseesUpdate 语句Update 语句用于修改表中的数据。语法:UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值Person:LastNameFirstNameAddressCityGatesBillXuanwumen 10BeijingWilsonChamps-Elysees更新某一行中的一个列我们为 lastname 是 Wilson 的人添加 firstname:UPDATE P
21、erson SET FirstName = Fred WHERE LastName = Wilson 结果:LastNameFirstNameAddressCityGatesBillXuanwumen 10BeijingWilsonFredChamps-Elysees更新某一行中的若干列我们会修改地址(address),并添加城市名称(city):UPDATE Person SET Address = Zhongshan 23, City = NanjingWHERE LastName = Wilson结果:LastNameFirstNameAddressCityGatesBillXuanwu
22、men 10BeijingWilsonFredZhongshan 23Nanjing Previous Page Next Page DELETE 语句DELETE 语句用于删除表中的行。语法DELETE FROM 表名称 WHERE 列名称 = 值Person:LastNameFirstNameAddressCityGatesBillXuanwumen 10BeijingWilsonFredZhongshan 23Nanjing删除某行Fred Wilson 会被删除:DELETE FROM Person WHERE LastName = Wilson 结果:LastNameFirstNam
23、eAddressCityGatesBillXuanwumen 10Beijing删除所有行可以在不删除表的情况下删除所有的行。这意味着表的结构、属性和索引都是完整的:DELETE FROM table_name或者:DELETE * FROM table_nameTOP 子句TOP 子句用于规定要返回的记录的数目。对于拥有数千条记录的大型表来说,TOP 子句是非常有用的。注释:并非所有的数据库系统都支持 TOP 子句。SQL Server 的语法:SELECT TOP number|percent column_name(s)FROM table_nameMySQL 和 Oracle 中的 S
24、QL SELECT TOP 是等价的MySQL 语法SELECT column_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 StreetLondon2BushGeorg
25、eFifth AvenueNew York3CarterThomasChangan StreetBeijing4ObamaBarackPennsylvania AvenueWashingtonSQL TOP 实例现在,我们希望从上面的 Persons 表中选取头两条记录。我们可以使用下面的 SELECT 语句:SELECT TOP 2 * FROM Persons结果:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew YorkSQL TOP PERCENT 实例现在,我们希
26、望从上面的 Persons 表中选取 50% 的记录。我们可以使用下面的 SELECT 语句:SELECT TOP 50 PERCENT * FROM Persons结果:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York操作符用于在 WHERE 子句中搜索列中的指定模式。LIKE 操作符LIKE 操作符用于在 WHERE 子句中搜索列中的指定模式。SQL LIKE 操作符语法SELECT column_name(s)FROM table_nameWHERE col
27、umn_name LIKE pattern原始的表 (用在例子中的):Persons 表:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetBeijingLIKE 操作符实例例子 1现在,我们希望从上面的 Persons 表中选取居住在以 N 开始的城市里的人:我们可以使用下面的 SELECT 语句:SELECT * FROM PersonsWHERE City LIKE N%提示:% 可用于定义通配符(模式中缺
28、少的字母)。结果集:IdLastNameFirstNameAddressCity2BushGeorgeFifth AvenueNew York例子 2接下来,我们希望从 Persons 表中选取居住在以 g 结尾的城市里的人:我们可以使用下面的 SELECT 语句:SELECT * FROM PersonsWHERE City LIKE %g结果集:IdLastNameFirstNameAddressCity3CarterThomasChangan StreetBeijing例子 3接下来,我们希望从 Persons 表中选取居住在包含 lon 的城市里的人:我们可以使用下面的 SELECT
29、语句:SELECT * FROM PersonsWHERE City LIKE %lon%结果集:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon例子 4通过使用 NOT 关键字,我们可以从 Persons 表中选取居住在不包含 lon 的城市里的人:我们可以使用下面的 SELECT 语句:SELECT * FROM PersonsWHERE City NOT LIKE %lon%结果集:IdLastNameFirstNameAddressCity2BushGeorgeFifth AvenueNew York3CarterT
30、homasChangan StreetBeijing在搜索数据库中的数据时,您可以使用 SQL 通配符。SQL 通配符在搜索数据库中的数据时,SQL 通配符可以替代一个或多个字符。SQL 通配符必须与 LIKE 运算符一起使用。在 SQL 中,可使用以下通配符:通配符描述%替代一个或多个字符_仅替代一个字符charlist字符列中的任何单一字符charlist或者!charlist不在字符列中的任何单一字符原始的表 (用在例子中的):Persons 表:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeF
31、ifth AvenueNew York3CarterThomasChangan StreetBeijing使用 % 通配符例子 1现在,我们希望从上面的 Persons 表中选取居住在以 Ne 开始的城市里的人:我们可以使用下面的 SELECT 语句:SELECT * FROM PersonsWHERE City LIKE Ne%结果集:IdLastNameFirstNameAddressCity2BushGeorgeFifth AvenueNew York例子 2接下来,我们希望从 Persons 表中选取居住在包含 lond 的城市里的人:我们可以使用下面的 SELECT 语句:SELEC
32、T * FROM PersonsWHERE City LIKE %lond%结果集:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon使用 _ 通配符例子 1现在,我们希望从上面的 Persons 表中选取名字的第一个字符之后是 eorge 的人:我们可以使用下面的 SELECT 语句:SELECT * FROM PersonsWHERE FirstName LIKE _eorge结果集:IdLastNameFirstNameAddressCity2BushGeorgeFifth AvenueNew York例子 2接下来,我
33、们希望从 Persons 表中选取的这条记录的姓氏以 C 开头,然后是一个任意字符,然后是 r,然后是任意字符,然后是 er:我们可以使用下面的 SELECT 语句:SELECT * FROM PersonsWHERE LastName LIKE C_r_er结果集:IdLastNameFirstNameAddressCity3CarterThomasChangan StreetBeijing使用 charlist 通配符例子 1现在,我们希望从上面的 Persons 表中选取居住的城市以 A 或 L 或 N 开头的人:我们可以使用下面的 SELECT 语句:SELECT * FROM Per
34、sonsWHERE City LIKE ALN%结果集:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York例子 2现在,我们希望从上面的 Persons 表中选取居住的城市不以 A 或 L 或 N 开头的人:我们可以使用下面的 SELECT 语句:SELECT * FROM PersonsWHERE City LIKE !ALN%结果集:IdLastNameFirstNameAddressCity3CarterThomasChangan StreetBeijingI
35、N 操作符IN 操作符允许我们在 WHERE 子句中规定多个值。SQL IN 语法SELECT column_name(s)FROM table_nameWHERE column_name IN (value1,value2,.)原始的表 (在实例中使用:)Persons 表:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetBeijingIN 操作符实例现在,我们希望从上表中选取姓氏为 Adams 和 Cart
36、er 的人:我们可以使用下面的 SELECT 语句:SELECT * FROM PersonsWHERE LastName IN (Adams,Carter)结果集:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon3CarterThomasChangan StreetBeijingBETWEEN 操作符在 WHERE 子句中使用,作用是选取介于两个值之间的数据范围。BETWEEN 操作符操作符 BETWEEN . AND 会选取介于两个值之间的数据范围。这些值可以是数值、文本或者日期。SQL BETWEEN 语法SELECT
37、 column_name(s)FROM table_nameWHERE column_nameBETWEEN value1 AND value2原始的表 (在实例中使用:)Persons 表:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetBeijing4GatesBillXuanwumen 10BeijingBETWEEN 操作符实例如需以字母顺序显示介于 Adams(包括)和 Carter(不包括)之间的人
38、,请使用下面的 SQL:SELECT * FROM PersonsWHERE LastNameBETWEEN Adams AND Carter结果集:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York重要事项:不同的数据库对 BETWEEN.AND 操作符的处理方式是有差异的。某些数据库会列出介于 Adams 和 Carter 之间的人,但不包括 Adams 和 Carter ;某些数据库会列出介于 Adams 和 Carter 之间并包括 Adams 和 Cart
39、er 的人;而另一些数据库会列出介于 Adams 和 Carter 之间的人,包括 Adams ,但不包括 Carter 。所以,请检查你的数据库是如何处理 BETWEEN.AND 操作符的!实例 2如需使用上面的例子显示范围之外的人,请使用 NOT 操作符:SELECT * FROM PersonsWHERE LastNameNOT BETWEEN Adams AND Carter结果集:IdLastNameFirstNameAddressCity3CarterThomasChangan StreetBeijing4GatesBillXuanwumen 10Beijing通过使用 SQL,可
40、以为列名称和表名称指定别名(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.OrderID, p.Las
41、tName, p.FirstNameFROM Persons AS p, Product_Orders AS poWHERE p.LastName=Adams AND p.FirstName=John不使用别名的 SELECT 语句:SELECT Product_Orders.OrderID, Persons.LastName, Persons.FirstNameFROM Persons, Product_OrdersWHERE Persons.LastName=Adams AND Persons.FirstName=John从上面两条 SELECT 语句您可以看到,别名使查询程序更易阅读和书写。Alias 实例: 使用一个列名别名表 Persons:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetBeijingSQL:SELECT LastName AS Family, FirstName AS NameFROM Persons结果:FamilyNameAdamsJohnBushGeorgeCarterThomasjoin 用于根据两个或多个表中的列之间的关系,从这些
限制150内