SQL语句教程大全

上传人:新** 文档编号:560193010 上传时间:2024-02-04 格式:DOC 页数:32 大小:127.50KB
返回 下载 相关 举报
SQL语句教程大全_第1页
第1页 / 共32页
SQL语句教程大全_第2页
第2页 / 共32页
SQL语句教程大全_第3页
第3页 / 共32页
SQL语句教程大全_第4页
第4页 / 共32页
SQL语句教程大全_第5页
第5页 / 共32页
点击查看更多>>
资源描述

《SQL语句教程大全》由会员分享,可在线阅读,更多相关《SQL语句教程大全(32页珍藏版)》请在金锄头文库上搜索。

1、无论您是一位 SQL 的新手,或是一位只是需要对 SQL 复习一下的资料仓储业界老将,您就 来对地方了。这个 SQL 教材网站列出常用的 SQL 指令 ,包含以下几个部分:? SQL 指令 : SQL 如何被用来储存、读取、以及处理数据库之中的资料。? 表格处理 : SQL 如何被用来处理数据库中的表格。? 进阶 SQL: 介绍 SQL 进阶概念,以及如何用 SQL 来执行一些较复杂的运算。? SQL 语法 : 这一页列出所有在这个教材中被提到的 SQL 语法。对于每一个指令,我们将会先列出及解释这个指令的语法,然后用一个例子来让读者了解这 个指令是如何被运用的。 当您读完了这个网站的所有教材

2、后, 您将对 SQL 的语法会有一个大 致上的了解。另外,您将能够正确地运用 SQL 来由数据库中获取信息。笔者本身的经验是, 虽然要对 SQL 有很透彻的了解并不是一朝一夕可以完成的,可是要对 SQL 有个基本的了解 并不难。希望在看完这个网站后,您也会有同样的想法。SQL指令SELECT是用来做什么的呢?一个最常用的方式是将资料从数据库中的表格内选出。 从这一句回答中, 我们马上可以看到两个关键字: 从 (FROM) 数据库中的表格内选出 (SELECT) 。(表格是一个 数据库内的结构, 它的目的是储存资料。 在表格处理这一部分中, 我们会提到如何使用 SQL 来 设定表格。 ) 我们由

3、这里可以看到最基本的 SQL 架构:SELECT 栏位名 FROM 表格名 我们用以下的例子来看看实际上是怎么用的。假设我们有以下这个表格:store_name Sales Date Los Angeles $1500 Jan-05-1999 San Diego $250 Jan-07-1999 Los Angeles $300 Jan-08-1999 Boston $700 Jan-08-1999 若要选出所有的店名 (store_Name) ,我们就打入:SELECT store_name FROM Store_Information结果:store_nameLos AngelesSan

4、DiegoLos AngelesBoston 我们一次可以读取好几个栏位,也可 以同时由好几个表格中选资料。DISTINCTSELECT指令让我们能够读取表格中一个或数个栏位的所有资料。这将把所有的资料都抓出, 无论资料值有无重复。 在资料处理中, 我们会经常碰到需要找出表格内的不同资料值的情况。 换句话说,我们需要知道这个表格 / 栏位内有哪些不同的值,而每个值出现的次数并不重要。 这要如何达成呢?在 SQL 中,这是很容易做到的。 我们只要在 SELECT 后加上一个 DISTINCT 就可以了。 DISTINCT 的语法如下:SELECT DISTINCT 栏位名 FROM 表格名 举例

5、来说,若要在以下的表格, Store_Information ,找出所有不同的店名时,Store_Information 表格store_name Sales Date Los Angeles $1500 Jan-05-1999 San Diego $250 Jan-07-1999 LosAngeles $300 Jan-08-1999 Boston $700 Jan-08-1999我们就键入,SELECT DISTINCT store_name FROM Store_Information结果: store_nameLos AngelesSan DiegoBostonWHERE我们并不一定每

6、一次都要将表格内的资料都完全抓出。在许多时候,我们会需要选择性地抓 资料。就我们的例子来说,我们可能只要抓出营业额超过 $1,000 的资料。要做到这一点, 我们就需要用到WHERE这个指令。这个指令的语法如下:SELECT 栏位名 FROM 表格名 WHERE 条 件 若我们要由以下的表格抓出营业额超过 $1,000 的资料,Store_Information 表格store_name Sales Date Los Angeles $1500 Jan-05-1999 San Diego $250 Jan-07-1999 LosAngeles $300 Jan-08-1999 Boston $

7、700 Jan-08-1999我们就键入,SELECT store_nameFROM Store_InformationWHERE Sales 1000结果:store_nameLos AngelesAND OR在上一页中,我们看到WHERE指令可以被用来由表格中有条件地选取资料。这个条件可能是简单的 ( 像上一页的例子 ) ,也可能是复杂的。 复杂条件是由二或多个简单条件透过 AND 或 是 OR 的连接而成。一个 SQL 语句中可以有无限多个简单条件的存在。复杂条件的语法如下:SELECT 栏位名 FROM 表格名 WHERE 简 单条件 AND|OR 简单条件 + 代表 之内的情况会发生

8、一或多次。 在这里的意思就是 AND 加简单条件及 OR 加简单条 件的情况可以发生一或多次。另外,我们可以用 () 来代表条件的先后次序。举例来说,我们若要在 Store_Information 表格中选出所有 Sales 高于 $1,000 或是 Sales 在 $500 及 $275 之间的资料的话,Store_Information 表格store_name Sales Date Los Angeles $1500 Jan-05-1999 San Diego $250 Jan-07-1999 San Francisco $300 Jan-08-1999 Boston $700 Jan-

9、08-1999我们就键入,SELECT store_nameFROM Store_InformationWHERE Sales 1000OR (Sales 275)结果:store_nameLos AngelesSan FranciscoIN在SQL中,在两个情况下会用到 IN这个指令;这一页将介绍其中之一:与WHERE有关的 那一个情况。在这个用法下,我们事先已知道至少一个我们需要的值,而我们将这些知道的 值都放入 IN 这个子句。 IN 指令的语法为下:SELECT 栏位名 FROM 表格名 WHERE 栏 位名 IN ( 值一, 值二, .)在括号内可以有一或多个值,而不同值之间由逗点分

10、开。值可以是数目或是文字。若在括号 内只有一个值,那这个子句就等于WHERE 栏 位名 = 值一举例来说,若我们要在 Store_Information 表格中找出所有含盖 Los Angeles 或 San Diego 的资料,Store_Information 表格store_name Sales Date Los Angeles $1500 Jan-05-1999 San Diego $250 Jan-07-1999 SanFrancisco $300 Jan-08-1999 Boston $700 Jan-08-1999 我们就键入,SELECT *FROM Store_Informa

11、tionWHERE store_name IN (Los Angeles, San Diego)结果:store_name Sales Date Los Angeles $1500 Jan-05-1999 San Diego $250 Jan-07-1999 BETWEENIN 这个指令可以让我们依照一或数个不连续 (discrete) 的值的限制之内抓出资料库中的值,而BETWEEN则是让我们可以运用一个范围(range)内抓出资料库中的值。BETWEEN这个子句的语法如下:SELECT 栏位名 FROM 表格名 WHERE 栏 位名 BETWEEN 值一 AND 值二这将选出栏位值包含在值

12、一及值二之间的每一笔资料。举例来说,若我们要由 Store_Information 表格中找出所有介于 January 6, 1999 及 January 10, 1999 中的资料,Store_Information 表格store_name Sales Date Los Angeles $1500 Jan-05-1999 San Diego $250 Jan-07-1999 San Francisco $300 Jan-08-1999 Boston $700 Jan-08-1999 我们就键入,SELECT *FROM Store_InformationWHERE Date BETWEEN

13、 Jan-06-1999 AND Jan-10-1999请读者注意:在不同的数据库中,日期的储存法可能会有所不同。在这里我们选择了其中一 种储存法。推荐一个免费 web 数据库软件, magicflu ,魔方网表,一个月就能赚 2 万,比常规开发效率 高 10 倍免费版下载安装地址http:/ Sales Date San Diego $250 Jan-07-1999 San Francisco $300 Jan-08-1999Boston $700 Jan-08-1999 LIKELIKE是另一个在 WHERE子句中会用到的指令。基本上,LIKE能让我们依据一个模式(pattern) 来找出

14、我们要的资料。相对来说,在运用 IN 的时候,我们完全地知道我们需要 的条件;在运用 BETWEEN的时候,我们则是列出一个范围。LIKE的语法如下:SELECT 栏位名 FROM 表格名 WHERE 栏 位名 LIKE 模式 模式 经常包括野卡 (wildcard). 以下是几个例子:A_Z: 所有以 A 起头,另一个任何值的字原,且以 Z 为结尾的字符串。 ABZ 和 A2Z 都符合这一个模式,而 AKKZ 并不符合 ( 因为在 A 和 Z 之间有两个字原,而不是 一个字原 ) 。ABC%: 所有以 ABC 起头的字符串。举例来说,ABCD 和 ABCABC 都符合这个模式。%XYZ: 所

15、有以 XYZ 结尾的字符串。举例来说,WXYZ 和 ZZXYZ 都符合这个模式。%AN%:所有含有AN这个模式的字符串。举例来说,LOS ANGELES和SAN FRANCISCO 都符合这个模式。我们将以上最后一个例子用在我们的 Store_Information 表格上 :Store_Information 表格store_name Sales Date LOS ANGELES $1500 Jan-05-1999 SAN DIEGO $250 Jan-07-1999 SANFRANCISCO $300 Jan-08-1999 BOSTON $700 Jan-08-1999 我们就键入,SELECT *FROM Store_Informati

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 办公文档 > 工作计划

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号