SQL数据语言的入门教程_第1页
SQL数据语言的入门教程_第2页
SQL数据语言的入门教程_第3页
SQL数据语言的入门教程_第4页
SQL数据语言的入门教程_第5页
已阅读5页,还剩13页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、SQL数据语言的快速入门【简介】SQL是英文Structured Query Language的缩写,意思为结构化查询语言.SQL语言的主要功能就是同各种数据库建立联系,进行沟通.根据ANSI 美国国家标准协会的规定,SQL被作为关系型数据库治理系统的标准语言.SQL语句可以用来执行各种各样的操作,例如更新数据库中的数据,从数据库中提取数据 等.目前,绝大多数流行的关系型数据库治理系统,如Oracle, Sybase, Microsoft SQL Server, Access 等都采用了 SQL语言标准.虽然很多数据库都对 SQL语句进行了再开发和扩展,但是包括Select, Insert,

2、Update, Delete, Create,以及Drop在内的标准的SQL命令仍然可以被用来完成几乎所有的数据库操作.下面,我 们就来详细介绍一下 SQL语言的根本知识.一个典型的关系型数据库通常由一个或多个被称作表格的对象组成.数据库中的所有数据或信息都被保存 在这些数据库表格中.数据库中的每一个表格都具有自己唯一的表格名称,都是由行和列组成,其中每一 列包括了该列名称,数据类型,以及列的其它属性等信息,而行那么具体包含某一列的记录或数据.以下, 是一个名为天气的数据库表格的实例.QUOTE:城市最高气温最低气温北京10 5上海15 8天津8 2重庆20 13该表格中城市最高气温和最低气温

3、就是三个不同的列,而表格中的每一行那么包含了具体的表格数据.数据查询在众多的SQL命令中,select语句应该算是使用最频繁的.Select语句主要被用来对数据库进行查询并返回符合用户查询标准的结果数据.Select语句的语法格式如下:QUOTE:select column1 , column2,etc from tablenamewhere condition;表示可选项select语句中位于select关键词之后的列名用来决定那些列将作为查询结果返回.用户可以根据自己的需要选择任意列,还可以使用通配符“* 设定返回表格中的所有列.select语句中位于from关键词之后的表格名称用来决定将

4、要进行查询操作的目标表格.Select语句中的where可选从句用来规定哪些数据值或哪些行将被作为查询结果返回或显示.在where条件从句中可以使用以下一些运算符来设定查询标准:QUOTE:=等于大于小于 =大于等于v =小于等于O不等于除了上面所提到的运算符外,LIKE运算符在where条件从句中也非常重要.LIKE运算符的功能非常 强大,通过使用口KE运算符可以设定只选择与用户规定格式相同的记录.此外,我们还可以使用通配符“用来代替任何字符串.举例如下:QUOTE:select firstname, lastname, cityfrom employeewhere firstname LI

5、KE E%'(注意,字符串必须被包含在单括号内)上述SQL语句将会查询所有名称以E开头的姓名.或者,通过如下语句:QUOTE:select * from employeewhere firstname = Ma;'查询所有名称为May的行.SQL语言中的create table语句被用来建立新的数据库表格.Create table语句的使用格式如下:QUOTE:create table tablename(column1 data type,column2 data type,column3 data type);如果用户希望在建立新表格时规定列的限制条件,可以使用可选的条件选

6、项:QUOTE:create table tablename(columnl data type constraint,column2 data type constraint,column3 data type constraint);举例如下:QUOTE:create table employee(firstname varchar(15),lastname varchar(20),age number(3),address varchar(30),city varchar(20);简单来说,创立新表格时,在关键词create table后面参加所要建立的表格的名称,然后在括号内顺次设定各

7、列的名称,数据类型,以及可选的限制条件等.注意,所有的SQL语句在结尾处都要使用;“符号.使用SQL语句创立的数据库表格和表格中列的名称必须以字母开头,后面可以使用字母,数字或下划线,名称的长度不能超过30个字符.注意,用户在选择表格名称时不要使用SQL语言中的保存关键词,如select,create, insert等,作为表格或列的名称.数据类型用来设定某一个具体列中数据的类型.例如,在姓名列中只能采用varchar或char的数据类型,而不能使用number的数据类型.SQL语言中较为常用的数据类型为:QUOTE:char(size):固定长度字符串,其中括号中的size用来设定字符串的最

8、大长度.Char类型的最大长度为255字节.varchar(size):可变长度字符串,最大长度由size设定.number(size):数字类型,其中数字的最大位数由size设定.Date :日期类型.number(size,d):数字类型,size决定该数字总的最大位数,而d那么用于设定该数字在小数点后的位数.最后,在创立新表格时需要注意的一点就是表格中列的限制条件.所谓限制条件就是当向特定列输入数据 时所必须遵守的规那么.例如,unique这一限制条件要求某一列中不能存在两个值相同的记录,所有记录的 值都必须是唯一的.除 unique之外,较为常用的列的限制条件还包括not null和p

9、rimary key等.Not null用来规定表格中某一列的值不能为空.Primary key那么为表格中的所有记录规定了唯一的标识符.向表格中插入数据SQL语言使用insert语句向数据库表格中插入或添加新的数据行.Insert语句的使用格式如下:QUOTE:insert into tablename(first_column,.last_column)values (first_value,.last_value); 例如:/quoteinsert into employee(firstname, lastname, age, address, city)values ( Li '

10、; , Ming ' , 45, No.77 Changan Road ' , Beijing ); /quote简单来说,当向数据库表格中添加新记录时,在关键词insert into后面输入所要添加的表格名称,然后在括号中列岀将要添加新值的列的名称.最后,在关键词values的后面根据前面输入的列的顺序对应的输入所有要添加的记录值.更新记录SQL语言使用update语句更新或修改满足规定条件的现有记录.Update语句的格式为:QUOTE:update tablenameset columnname = newvalue , nextcolumn = newvalue2whe

11、re columnname OPERATOR value and or column OPERATOR value;例如:QUOTE:update employee set age = age+1where first_name= Mary ' iasd_name= Williams '使用update语句时,关键一点就是要设定好用于进行判断的where条件从句.删除记录SQL语言使用delete语句删除数据库表格中的行或记录.Delete语句的格式为:QUOTE:delete from tablenamewhere columnname OPERATOR value and

12、or column OPERATOR value;例如:QUOTE:delete from employeewhere lastname = May;简单来说,当需要删除某一行或某个记录时,在delete from 关键词之后输入表格名称,然后在 where从句中设定删除记录的判断条件.注意,如果用户在使用delete语句时不设定 where从句,那么表格中的所有记录将全部被删除.删除数据库表格在SQL语言中使用drop table命令删除某个表格以及该表格中的所有记录.Drop table命令的使用格式为:QUOTE:drop table tablename ;例如:QUOTE:drop t

13、able employee;如果用户希望将某个数据库表格完全删除,只需要在drop table命令后输入希望删除的表格名称即可.Droptable命令的作用与删除表格中的所有记录不同.删除表格中的全部记录之后,该表格仍然存在,而且表格 中列的信息不会改变.而使用drop table命令那么会将整个数据库表格的所有信息全部删除.以上,我们对SQL语言主要的命令和语句进行了较为详细的介绍.应该说SQL语句的语法结构和风格还是相当简单和直观的,只要用户结合实践多加练习,一定会在短期内迅速掌握.SELECTFROM为方便讲解,我们在数据库中创立名为Store_Information 的如下数据表QUO

14、TE:Store_lnformationStore_NameSalesDateLos Angeles$1500Jan-10-2000San Diego$250Jan-11-2000Los Angeles$300Jan-12-2000Boston$700Jan-12-2000SQL语言中用于数据库查询的最简单的命令就是SELECTFROM语法格式为:QUOTE:SELECT "column_name" FROM "table_name"例如,如果我们希望查询 Store_Information 数据表中所有的商店名称时,可以使用如下命令:QUOTE:SEL

15、ECT store_name FROM Store_Information查询结果显示为:QUOTE:Store_NameLos AngelesSan DiegoLos AngelesBoston如果用户希望一次查询多个字段,可以将所要查询的字段名称依次参加SELECT关键字之后,中间用隔开即可.DISTINCTSELECT关键字支持用户查询数据表中指定字段的所有数据,但是这样有时就会不可防止的岀现重复信息.如果用户希望只查询那些具有不同记录值的信息的话,可以使用SQL语言的DISTINCT关键字.语法格式如下:QUOTE:SELECT DISTINCT "column_name&q

16、uot;FROM "table_name"例如,我们可以使用以下命令查询Store_lnformation 数据表具有不同记录值的所有记录.QUOTE:SELECT DISTINCT Store_Name FROM Store_lnformation 查询结果如下:QUOTE:Store_NameLos AngelesSan DiegoBostonWHERE除了选择具有不同记录值的记录之外,有时我们可能还会需要根据某些条件对数据库中的数据进行查询.例如,我们可能需要查询 Store_lnformation 数据表中销售额超过 1000美圆的商店.为此,我们可以使用SQL语言

17、的WHERE关键字设定查询条件.语法格式如下:QUOTE:SELECT "column_name"FROM "table_name"WHERE "condition"由此,我们可以使用如下命令查询销售额超过1000美圆的商店信息:QUOTE:SELECT store_name FROM Store_Information WHERE Sales > 1000查询结果显示为:QUOTE:store_nameLos Angeles运算函数现在,我们已经了解到在使用 SQL语言进行数据库查询操作时可以通过对数值的判断设定灵活的查询条件

18、.为了增强对运算的支持水平,SQL提供了众多实用的运算函数供广阔用户使用.例如,我们可以直接在SQL命令中调用SUM或AVG这两个分别用于计算总数和平均数的函数.语法格式如下:QUOTE:SELECT "function type"("column_name")FROM "table_name"如果我们希望查询Store_lnformation 数据表中所有商店的总销售额的话,可以使用如下命令:QUOTE:SELECT SUM(Sales) FROM Store_Information查询结果显示为:QUOTE:SUM(Sales)$

19、2750COUNT除了 SUM和AVG函数之外,COUNT函数是SQL语言中另一个较为常用的运算函数.COUNT函数可以用来计算数据表中指定字段所包含的记录数目.语法格式为:QUOTE:SELECT COUNT("column_name")FROM "table_name"例如,如果我们希望查询 Store_Information 数据表中的有关商店的记录条数时,可以使用如下命令:QUOTE:SELECT COUNT(store_name)FROM Store_Information查询结果显示为:QUOTE:Count(store_name)4COUN

20、T函数可以和DISTINCT关键字一起使用从而可以查询数据表中指定字段中所有具有不同记录值的记 录数目.例如,如果我们希望查询 Store_lnformation 数据表中不同商店的数目时,可以使用如下命令:QUOTE:SELECT COUNT(DISTINCT store_name)FROM Store_lnformation查询结果显示为:QUOTE:Count(DISTINCT store_name)3GROUP BY下面我们来进一步看一下 SQL语言中的集合函数.上文中,我们曾使用SUM函数计算所有商店的销售总额,如果我们希望计算每一家商店各自的总销售额时该怎么办呢?要实现这一目的我们

21、需要做两件事:首 先,我们需要查询商店名称和销售额两个字段;然后,我们使用SQL语言的GROUP BY命令将销售额根据不同的商店进行分组,从而计算出不同商店的销售总额.GROUP BY命令的语法格式为:QUOTE:SELECT "column_name1", SUM("column_name2")FROM "table_name"GROUP BY "column_name1"我们可以使用如下命令实现上述查询目的:QUOTE:SELECT store_name, SUM(Sales)FROM Store_lnform

22、ationGROUP BY store_name查询结果显示为:QUOTE:store_name SUM(Sales)Los Angeles $1800San Diego $250Boston $700小注:GROUP BY关键字一般应用于同时查询多个字段并对字段进行算术运算的SQL命令中HAVING用户在使用SQL语言的过程中可能希望解决的另一个问题就是对由sum或其它集合函数运算结果的输出进行限制.例如,我们可能只希望看到 Store_lnformation 数据表中销售总额超过 1500美圆的商店的信息, 这时我们就需要使用 HAVING从句.语法格式为:QUOTE:SELECT &qu

23、ot;column_name1", SUM("column_name2")FROM "table_name"GROUP BY "column_name1"HAVING (arithematic function condition)(GROUP BY从句可选)由此,我们可以使用如下命令实现上述查询目的:QUOTE:SELECT store_name, SUM(sales)FROM Store_lnformationGROUP BY store_nameHAVING SUM(sales) > 1500查询结果显示为:QU

24、OTE:store_name SUM(Sales)Los Angeles $1800小注:SQL语言中设定集合函数的查询条件时使用HAVING从句而不是 WHERE从句.通常情况下,HAVING从句被放置在SQL命令的结尾处.ALIAS下面,我们重点介绍一下如何在SQL命令中设定别名.SQL语言中一般使用两种类型的别名,分别为字段别名和数据表别名.简单的说,使用字段别名可以帮助我们有效的组织查询的输岀结果.例如,上文所列举的多个实例中,当我们计算商店销售总额时,显示结果中就会出现SUM(sales).虽然SUM(sales)并不会对我们理解查询结果带来不便,但是如果我们需要在查询中使用多项复杂

25、运算时,显示结果就不会这么直观了.如果这时我们 使用字段别名就会极大的提升查询结果的可读性.对于数据表别名,我们可以通过将别名直接放置在FROM从句中数据表名称的后面设定.数据表别名在我们下面将要讲述的连接多个数据表进行查询的操作中极为有用.字段和数据表别名的语法格式如下:QUOTE:SELECT "table_alias"."column_name1" "column_alias"FROM "table_name" "table_alias"即别名都直接放置在各自对应名称的后面,中间用空格分开

26、.以Store_lnformation 数据表为例,我们可以在 GROUP BY 一节中所使用的SQL命令中设置如下字段和数 据表别名:QUOTE:SELECT A1.store_name Store, SUM(Sales) "Total Sales"FROM Store_lnformation A1GROUP BY A1.store_name查询结果显示为:QUOTE:Store Total SalesLos Angeles $1800San Diego $250Boston $700连接多个数据表最后,我们来看一下如果使用SQL语言连接多个数据表,实现对多个数据表的查询.为方便讲解,我们在数据库中分别创立了两个名为Store_Information 和Region的数据表.QUOTE:Store_InformationStore_NameSalesDateLos Angeles$1500Jan-10-2000San Diego$250Jan-11-2000Los Angeles$300Jan-12-2000Boston$700Jan-12-2000QUOTE:RegionRegion_NameStore_NameEastBostonEastNew YorkWestLos AngelesWestSan Diego

温馨提示

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

评论

0/150

提交评论