1、sql语句的增删改查SQL 教程 Next PageSQL 是用于访问和处理数据库的标准的计算机语言。在本教程中,您将学到如何使用 SQL 访问和处理数据系统中的数据,这类数据库包括:Oracle, Sybase, SQL Server, DB2, Access 等等。开始学习 SQL !注:本教程中出现的姓名、地址等信息仅供教学,与实际情况无关。SQL 测验在 W3School 测试你的 SQL 技能!开始 SQL 测验 !SQL 简介 Previous Page Next PageSQL 是用于访问和处理数据库的标准的计算机语言。什么是 SQL? SQL 指结构化查询语言 SQL 使我们有
2、能力访问数据库 SQL 是一种 ANSI 的标准计算机语言编者注:ANSI,美国国家标准化组织SQL 能做什么? SQL 面向数据库执行查询 SQL 可从数据库取回数据 SQL 可在数据库中插入新的纪录 SQL 可更新数据库中的数据 SQL 可从数据库删除记录 SQL 可创建新数据库 SQL 可在数据库中创建新表 SQL 可在数据库中创建存储过程 SQL 可在数据库中创建视图 SQL 可以设置表、存储过程和视图的权限SQL 是一种标准 - 但是.SQL 是一门 ANSI 的标准计算机语言,用来访问和操作数据库系统。SQL 语句用于取回和更新数据库中的数据。SQL 可与数据库程序协同工作,比如
3、MS Access、DB2、Informix、MS SQL Server、Oracle、Sybase 以及其他数据库系统。不幸地是,存在着很多不同版本的 SQL 语言,但是为了与 ANSI 标准相兼容,它们必须以相似的方式共同地来支持一些主要的关键词(比如 SELECT、UPDATE、DELETE、INSERT、WHERE 等等)。注释:除了 SQL 标准之外,大部分 SQL 数据库程序都拥有它们自己的私有扩展!在您的网站中使用 SQL要创建发布数据库中数据的网站,您需要以下要素: RDBMS 数据库程序(比如 MS Access, SQL Server, MySQL) 服务器端脚本语言(比如
4、 PHP 或 ASP) SQL HTML / CSSRDBMSRDBMS 指的是关系型数据库管理系统。RDBMS 是 SQL 的基础,同样也是所有现代数据库系统的基础,比如 MS SQL Server, IBM DB2, Oracle, MySQL 以及 Microsoft Access。RDBMS 中的数据存储在被称为表(tables)的数据库对象中。表是相关的数据项的集合,它由列和行组成。SQL 语法 Previous Page Next Page数据库表一个数据库通常包含一个或多个表。每个表由一个名字标识(例如“客户”或者“订单”)。表包含带有数据的记录(行)。下面的例子是一个名为 Pe
5、rsons 的表:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetBeijing上面的表包含三条记录(每一条对应一个人)和五个列(Id、姓、名、地址和城市)。SQL 语句您需要在数据库上执行的大部分工作都由 SQL 语句完成。下面的语句从表中选取 LastName 列的数据:SELECT LastName FROM Persons结果集类似这样:LastNameAdamsBushCarter在本教程中,我们将为
6、您讲解各种不同的 SQL 语句。重要事项一定要记住,SQL 对大小写不敏感!SQL 语句后面的分号?某些数据库系统要求在每条 SQL 命令的末端使用分号。在我们的教程中不使用分号。分号是在数据库系统中分隔每条 SQL 语句的标准方法,这样就可以在对服务器的相同请求中执行一条以上的语句。如果您使用的是 MS Access 和 SQL Server 2000,则不必在每条 SQL 语句之后使用分号,不过某些数据库软件要求必须使用分号。SQL DML 和 DDL可以把 SQL 分为两个部分:数据操作语言 (DML) 和 数据定义语言 (DDL)。SQL (结构化查询语言)是用于执行查询的语法。但是
7、SQL 语言也包含用于更新、插入和删除记录的语法。查询和更新指令构成了 SQL 的 DML 部分: SELECT - 从数据库表中获取数据 UPDATE - 更新数据库表中的数据 DELETE - 从数据库表中删除数据 INSERT INTO - 向数据库表中插入数据SQL 的数据定义语言 (DDL) 部分使我们有能力创建或删除表格。我们也可以定义索引(键),规定表之间的链接,以及施加表间的约束。SQL 中最重要的 DDL 语句: CREATE DATABASE - 创建新数据库 ALTER DATABASE - 修改数据库 CREATE TABLE - 创建新表 ALTER TABLE -
8、变更(改变)数据库表 DROP TABLE - 删除表 CREATE INDEX - 创建索引(搜索键) DROP INDEX - 删除索引SQL SELECT 语句 Previous Page Next Page本章讲解 SELECT 和 SELECT * 语句。SQL SELECT 语句SELECT 语句用于从表中选取数据。结果被存储在一个结果表中(称为结果集)。SQL SELECT 语法SELECT 列名称 FROM 表名称以及:SELECT * FROM 表名称注释:SQL 语句对大小写不敏感。SELECT 等效于 select。SQL SELECT 实例如需获取名为 LastName
9、 和 FirstName 的列的内容(从名为 Persons 的数据库表),请使用类似这样的 SELECT 语句:SELECT LastName,FirstName FROM PersonsPersons 表:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetBeijing结果:LastNameFirstNameAdamsJohnBushGeorgeCarterThomasSQL SELECT * 实例现在我们希
10、望从 Persons 表中选取所有的列。请使用符号 * 取代列的名称,就像这样:SELECT * FROM Persons提示:星号(*)是选取所有列的快捷方式。结果:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetBeijing在结果集(result-set)中导航由 SQL 查询程序获得的结果被存放在一个结果集中。大多数数据库软件系统都允许使用编程函数在结果集中进行导航,比如:Move-To-First-R
11、ecord、Get-Record-Content、Move-To-Next-Record 等等。类似这些编程函数不在本教程讲解之列。如需学习通过函数调用访问数据的知识,请访问我们的 ADO 教程 和PHP 教程。SQL SELECT DISTINCT 语句 Previous Page Next Page本章讲解 SELECT DISTINCT 语句。SQL SELECT DISTINCT 语句在表中,可能会包含重复值。这并不成问题,不过,有时您也许希望仅仅列出不同(distinct)的值。关键词 DISTINCT 用于返回唯一不同的值。语法:SELECT DISTINCT 列名称 FROM 表
12、名称使用 DISTINCT 关键词如果要从 Company 列中选取所有的值,我们需要使用 SELECT 语句:SELECT Company FROM OrdersOrders表:CompanyOrderNumberIBM3532W3School2356Apple4698W3School6953结果:CompanyIBMW3SchoolAppleW3School请注意,在结果集中,W3School 被列出了两次。如需从 Company 列中仅选取唯一不同的值,我们需要使用 SELECT DISTINCT 语句:SELECT DISTINCT Company FROM Orders结果:Comp
13、anyIBMW3SchoolApple现在,在结果集中,W3School 仅被列出了一次。SQL SELECT DISTINCT 语句 Previous Page Next Page本章讲解 SELECT DISTINCT 语句。SQL SELECT DISTINCT 语句在表中,可能会包含重复值。这并不成问题,不过,有时您也许希望仅仅列出不同(distinct)的值。关键词 DISTINCT 用于返回唯一不同的值。语法:SELECT DISTINCT 列名称 FROM 表名称使用 DISTINCT 关键词如果要从 Company 列中选取所有的值,我们需要使用 SELECT 语句:SELEC
14、T Company FROM OrdersOrders表:CompanyOrderNumberIBM3532W3School2356Apple4698W3School6953结果:CompanyIBMW3SchoolAppleW3School请注意,在结果集中,W3School 被列出了两次。如需从 Company 列中仅选取唯一不同的值,我们需要使用 SELECT DISTINCT 语句:SELECT DISTINCT Company FROM Orders结果:CompanyIBMW3SchoolApple现在,在结果集中,W3School 仅被列出了一次。SQL AND & OR 运算符
15、 Previous Page Next PageAND 和 OR 运算符用于基于一个以上的条件对记录进行过滤。AND 和 OR 运算符AND 和 OR 可在 WHERE 子语句中把两个或多个条件结合起来。如果第一个条件和第二个条件都成立,则 AND 运算符显示一条记录。如果第一个条件和第二个条件中只要有一个成立,则 OR 运算符显示一条记录。原始的表 (用在例子中的):LastNameFirstNameAddressCityAdamsJohnOxford StreetLondonBushGeorgeFifth AvenueNew YorkCarterThomasChangan StreetBe
16、ijingCarterWilliamXuanwumen 10BeijingAND 运算符实例使用 AND 来显示所有姓为 Carter 并且名为 Thomas 的人:SELECT * FROM Persons WHERE FirstName=Thomas AND LastName=Carter结果:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingOR 运算符实例使用 OR 来显示所有姓为 Carter 或者名为 Thomas 的人:SELECT * FROM Persons WHERE firstname=Thomas
17、OR lastname=Carter结果:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingCarterWilliamXuanwumen 10Beijing结合 AND 和 OR 运算符我们也可以把 AND 和 OR 结合起来(使用圆括号来组成复杂的表达式):SELECT * FROM Persons WHERE (FirstName=Thomas OR FirstName=William)AND LastName=Carter结果:LastNameFirstNameAddressCityCarterThomasChang
18、an StreetBeijingCarterWilliamXuanwumen 10BeijingSQL AND & OR 运算符 Previous Page Next PageAND 和 OR 运算符用于基于一个以上的条件对记录进行过滤。AND 和 OR 运算符AND 和 OR 可在 WHERE 子语句中把两个或多个条件结合起来。如果第一个条件和第二个条件都成立,则 AND 运算符显示一条记录。如果第一个条件和第二个条件中只要有一个成立,则 OR 运算符显示一条记录。原始的表 (用在例子中的):LastNameFirstNameAddressCityAdamsJohnOxford Street
19、LondonBushGeorgeFifth AvenueNew YorkCarterThomasChangan StreetBeijingCarterWilliamXuanwumen 10BeijingAND 运算符实例使用 AND 来显示所有姓为 Carter 并且名为 Thomas 的人:SELECT * FROM Persons WHERE FirstName=Thomas AND LastName=Carter结果:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingOR 运算符实例使用 OR 来显示所有姓为 Car
20、ter 或者名为 Thomas 的人:SELECT * FROM Persons WHERE firstname=Thomas OR lastname=Carter结果:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingCarterWilliamXuanwumen 10Beijing结合 AND 和 OR 运算符我们也可以把 AND 和 OR 结合起来(使用圆括号来组成复杂的表达式):SELECT * FROM Persons WHERE (FirstName=Thomas OR FirstName=William)AND
21、 LastName=Carter结果:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingCarterWilliamXuanwumen 10BeijingSQL INSERT INTO 语句 Previous Page Next PageINSERT INTO 语句INSERT INTO 语句用于向表格中插入新的行。语法INSERT INTO 表名称 VALUES (值1, 值2,.)我们也可以指定所要插入数据的列:INSERT INTO table_name (列1, 列2,.) VALUES (值1, 值2,.)插入新的
22、行Persons 表:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingSQL 语句:INSERT INTO Persons VALUES (Gates, Bill, Xuanwumen 10, Beijing)结果:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingGatesBillXuanwumen 10Beijing在指定的列中插入数据Persons 表:LastNameFirstNameAddressCityCarterThomasChanga
23、n StreetBeijingGatesBillXuanwumen 10BeijingSQL 语句:INSERT INTO Persons (LastName, Address) VALUES (Wilson, Champs-Elysees)结果:LastNameFirstNameAddressCityCarterThomasChangan StreetBeijingGatesBillXuanwumen 10BeijingWilson Champs-Elysees SQL UPDATE 语句 Previous Page Next PageUpdate 语句Update 语句用于修改表中的数据。
24、语法:UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值Person:LastNameFirstNameAddressCityGatesBillXuanwumen 10BeijingWilson Champs-Elysees 更新某一行中的一个列我们为 lastname 是 Wilson 的人添加 firstname:UPDATE Person SET FirstName = Fred WHERE LastName = Wilson结果:LastNameFirstNameAddressCityGatesBillXuanwumen 10BeijingWilsonFred
25、Champs-Elysees 更新某一行中的若干列我们会修改地址(address),并添加城市名称(city):UPDATE Person SET Address = Zhongshan 23, City = NanjingWHERE LastName = Wilson结果:LastNameFirstNameAddressCityGatesBillXuanwumen 10BeijingWilsonFredZhongshan 23NanjingSQL DELETE 语句 Previous Page Next PageDELETE 语句DELETE 语句用于删除表中的行。语法DELETE FROM
26、 表名称 WHERE 列名称 = 值Person:LastNameFirstNameAddressCityGatesBillXuanwumen 10BeijingWilsonFredZhongshan 23Nanjing删除某行Fred Wilson 会被删除:DELETE FROM Person WHERE LastName = Wilson结果:LastNameFirstNameAddressCityGatesBillXuanwumen 10Beijing删除所有行可以在不删除表的情况下删除所有的行。这意味着表的结构、属性和索引都是完整的:DELETE FROM table_name或者:
27、DELETE * FROM table_nameSQL TOP 子句 Previous Page Next 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
28、例子SELECT *FROM PersonsLIMIT 5Oracle 语法SELECT column_name(s)FROM table_nameWHERE ROWNUM = number例子SELECT *FROM PersonsWHERE ROWNUM = 5原始的表 (用在例子中的):Persons 表:IdLastNameFirstNameAddressCity1AdamsJohnOxford StreetLondon2BushGeorgeFifth AvenueNew York3CarterThomasChangan StreetBeijing4ObamaBarackPennsylvania AvenueW
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1