SQl数据库快速入门必须掌握的四大基本语句.docx

上传人:夺命阿水 文档编号:1474622 上传时间:2024-06-29 格式:DOCX 页数:6 大小:24.44KB
返回 下载 相关 举报
SQl数据库快速入门必须掌握的四大基本语句.docx_第1页
第1页 / 共6页
SQl数据库快速入门必须掌握的四大基本语句.docx_第2页
第2页 / 共6页
SQl数据库快速入门必须掌握的四大基本语句.docx_第3页
第3页 / 共6页
SQl数据库快速入门必须掌握的四大基本语句.docx_第4页
第4页 / 共6页
SQl数据库快速入门必须掌握的四大基本语句.docx_第5页
第5页 / 共6页
点击查看更多>>
资源描述

《SQl数据库快速入门必须掌握的四大基本语句.docx》由会员分享,可在线阅读,更多相关《SQl数据库快速入门必须掌握的四大基本语句.docx(6页珍藏版)》请在课桌文档上搜索。

1、SQI数捌库快速入门必需驾(的四大基本谱句做一个系统的后台,基本上都少不了地捌改查,作为一个新手入门,我们必须要驾驭SQ1.四条最基本的数据操作谙句:InSert.Select.UPdate和DeIete!下面对这四个语句进行具体的剖析:娴熟驾驭SQ1.是数据库用户的珍货财宝,在本文中,我们将引导你驾坡四条加将本的数据操作语句-SQ1.的核心功能来依次介绍比较操作符、选择断言以及三值逻辑.当你完成这些学习后,明显你已羟起先算是真正SQl入门了.在我的起先之前,先运用CREATETA81E语句来创建个衣,DD1.语句对数据旅对象如表、列和视进行定义,它们并不对衣中的行进行处理,这是因为DDl语句

2、并不处理数据库中实际的数据.这些工作由另一类SQ1.语句数据操作谱言(DM1.)语句进行处理.SQ1.中有四种基本的DMl操作:INSERT.SE1.ECT.UPDATE41DE1.ETE,由于这是大多数SQI用户常常用到的,我们有必要在此对它们进行一一说明,在图1中我们给出了一个名为EMP1.OYEES的表。其中的母一行对应一个特定的雇员记录,请熟识这张衣,我们在后面的例子中将要用到它.INSERT语句用户可以用INSERT语句将一行记录插入到指定的一个表中,例如,要将展员JohnSlnith的记录插入到本例的表中,可以运用如卜语句:INSERTINTOEMP1.OYEESVA1.UES(S

3、mith7John,1980-0-10,1.osAngles,16,45000);通过这样的INSERT语句,系统将试芾将这些(ft埴入到相应的列中.这些列依据我们创建表时定义的依次排列.在本例中,第一个值“Smith”符列到第一个列1.AsT_NAME中:其次个值uJohn将城到其次列FlRS1.NAMEq以此类推.我们说过系统会一试存”将假填入,除了执行规则之外它还要iS行类型检杏。假如类型不符(如将一个字符小靖入到类型为数字的列中,系统将拒葩这一次操作并返回一个横误信息.假如SQ1.拒绝了你所填入的一列值,语句中其他各列的伯也不会填入.这是因为SQ1.供应对第务的支持,一次M务将数据库从

4、种一样性转移到另一种一样性,假如4务的某一部分失败,则整个事务都会失败,系统将会被女原(或称之为回退)到此事务之前的状态.回到原来的INSERT的例子,请留意全部的整形十进制数都不须要Hl单引号引起来,而字符率和日期类型的值都要用总引号来区分.为了增加可读性而在数字间插入逗号将会引起错误。记住,在SQl中逗号是元素的分隔符.同样要用意输入文字值时要运用单引号.双引号用来封装限界标识符。对于H期类型,我们必需运用SQ1.标准H期恪式yy-mm-dd),但是在系统中可以进行定义,以接受其他的格式.当然,2000年接近,请你最好还是运用四位来表示年份.既然你己经理解了INSERT语句是怎样工作的了,

5、让我们转到EMP1.OYEES衣中的其他部分:INSERTINTOEMP1.OYEESVA1.UES(Bunyan,Pau71970-07-04,Boston,12,700001;INSERTINTOEMP1.OYEESVA1.UESCJohnAdams71992-01-21lr,Boston20z1000);INSERTINTOEMP1.OYEESVA1.UES(,Smth7Pocahontas7197604-06z,1.osAngles;12,l0);INSERTINTOEMP1.OYEESVA1.UES(,Smlth7Bessie194005-02,Boston5,200000);INS

6、ERTINTOEMP1.OYEESVA1.UESCJones,Davy,197040-10rBoStOn:8,4SOO0);INSERTINTOEMP1.OYEESVA1.UES(,Jo11es,lndiana71992-02-01rChicagotzNU1.UNU1.1.);在最终一项中,我们不知道Jones先生的工薪级别和年薪,所以我们输入NUIl(不要引号)NU1.1.是SQl中的种特别状况,我们以后将迸行具体的探讨。现在我们只需认为NU1.1.表示一种未知的值.有时,像我们刚才所探讨的状况.我们可能希望对某一些而不是全部的列进行赋值C除了对要省略的列输入NU1.1.外,还可以采纳另外一

7、种INSERT语句,如下:INSERTINTOEMP1.OYEEFIRST_NAME,IAST_NAME,HIRE_DATE,BRANCH_0FFiCE)VAlE(,lndiana7Jones,1992-02-017ndianapolis,);这样,我们先在我名之后列出一系列列名.未列出的列中将自动填入缺省值,假如没有设时缺各值则埴入NU1.1.,请稻您我们变更了列的依次,而俏的依次要对应新的列的依次。假如该语句中省略了FlRST_NAME和1.AS1.NAME项(这两项规定不能为空),SQl操作将失败.让我们来看一看上述INSERT语句的语法图:INSERTINTOtable(column,

8、column)VA1.UES(columnvalue(,columnvalue);和前篇文章中一样,我们用方括号来表示可选项,大括号表示可以原现随意次数的项(不能在实际的SQ1.语句中运用这特别字符),VA1.UE子句和可选的列名列表中必需运用网括号.SE1.ECT语句SE1.ECT语句可以从一个或多个衣中选取特定的行和列.因为杳询和检索数据是数据库管理中最取婴的功能,所以SE1.ECr语句在S3中是工作T最大的部分。事实上,仅仅是访问数据库来分析数据并生成报表的人可以对其他SQ1.谙句一窍不通.SE1.ECT语句的结果通常是生成另外一个表.在执行过程中系统依据用户的标准从数据阵中选出匹配的行

9、和列,并将结果放到临时的表中。在干脆SQlyreCtSQIJ中,它将结果显示在终端的显示屏上,或者将结果送到打卬机或文件中,也可以结合其他SQ1.语句来将结果放到一个已知名称的表中.SE1.ECT语句功能强大.虽然表面上看来它只用来完成本文第一郃分中提到的关系代数运算“选择”(或称“限制”),但步实上它也可以完成其他两种关系运算一“投影”和连接“,SE1.ECT语句还UJ以完成聚合计算并对数据进行持序。SE1.ECr谱句最简洁的语法如下:SE1.ECTcolumnsFROMtables;当我们以这种形式执行一条SE1.ECT语句时,系统返回由所选择的列以及用户选择的表中全部指定的行组成的一个结

10、果衣。这就是实现关系投影运算的一个形式。让我们看一下运用图1中EMP1.OYEES表的一些例子(这个表是我们以后全部SE1.ECT语句实例都要运用的.而我们在图2和图3中给出了查彻的实际结果.我们将在其他的例干中运用这些结果)。假设你想杳看雇员工作部门的列表。那卜面就是你所须要编写的SQ1.杳询:SE1.ECTBRANCH_OFFICEFROMEMP1.OYEES;以上SE1.ECT喷句的执行珞产生如图2中表2所示的结梁.由于我们在SElEeT语句中只指定了一个列,所以我们的结果表中也只有个列留意结果表中具有重生的行,这是因为有多个雇员在同一部门工作(记住SQ1.从所选的全部行中将值返回).要

11、消退结果中的里亚行,只要在SE1.ECT语句中加DISTINCTf句:SE1.ECTDISTINCTBRANCH_OFFICEFROMEMP1.OYEES;这次查询的结果如表3所示。现在已经消退Jft更的行.但结果并不是依据依次排列的.如你希里以字母表依次将结果列出又该怎么做呢?只要运用ORDERBY子句就可以依据升序或降序来排列结果:SE1.ECTDISTINCTBRANCH_OFFlCEFROMEMP1.OYEESORDERBYBRANCH_OFFICEASC;这一5询的结果如我4所示.请留意在ORDERBY之后是如何放置列名BRANCH,OFFICE的,这就是我们想要对其进行排序的列,为

12、什么即使是结果表中只有一个列时我们也必需指出列名呢?这是因为我们还能将依据表中其他列进行排序,即使它们并不显示出来。列名BRANCH,OFFICE之后的关设字.ASC表示依据升序排列.假如你桁望以降序排列.那么可以用关键字DESC,同样我In应当指出ORDERBY子句只将临时衣中的结果进行排序:并不影响原来的表,假设我们希望得到按部门排序并从工资最高的雇员到工资最低的雇员排列的列表,除了工资括号中的内容,我们还带班看到依据聘用时间从最近聘用的雇员起先列出的列表.以下是你将要用到的语句:SE1.ECTBRANCH_OFFlCE,FIRST_NAME,1.AST_NAME,SA1.ARXHIRE_

13、DATEFROMEMP1.OYEESOrderbysalarydesc,HIRE.OATEOESC;这里我们进行了多列的选择和排序。排序的优先姒由语句中的列名依次所确定。SQ1.将先对列出的第一个列进行排序.假如在第一个列中出现了理红的行时,这些行将被依据其次列进行排序,假如在其次列中又出现了柬虹的行时,这些行又将被依据第三列进行排序如此类推。这次直询的结果如表5所示。将一个很长的表中的全部列名目出来是一件相当麻烦的事,所以SQ1.允许在选择表中全部的列时运用*号:SE1.ECTFROMEMP1.OYEES;这次杳泡诋回整个EMPlOYEES表,如表1所示。卜面我们对起先时给出的SEIECT语

14、句的语法进行卜更新(轻自我表示一个可选项,允许在其中选择一项.):SE1.ECTDISTINCT(column(,columns)!FROMtable(,tableORDERBYcolumn(ASCJDESC(,columnASCDESCJ;定义选择标准在我们目前所介绍的SE1.ECT语句中,我们对结果表中的列作出了选择但返回的是表中全部的行.让我们看一下如何对SE1.ECT谱句进行限制使得它只返回希望得到的行:SE1.ECTcolumnsFROMtablesWHEREpredicates;WHERE子句对条件进行了设置,只有满造条件的行才被包括到结果表中。这些条件由断有(predicate)

15、进行指定(断言指出了关于某件事情的一种可能的事实)。黄如该断言对于某个给定的行成立,该行构被包括到结果表中,否则该行被忽视.在SQ1.谱句中断言遹常通过比较来龙示.例如,假如你须要查询全部姓为Jones的职员,则可以运用以下SE1.ECT语句:SE1.ECT,FROMEMP1.OYEESWHERE1.AST_NAME=Jones;1.AST_NAME=UOneS邻分就是断言.在执行该语句时,SQ1.将每一行的IASi1.NAME列与“Jones”进行比较,假如某一职员的姓为“Jones”,即断言成立,该职员的信息将被包括到结果表中(见表6.运用最多的六种比较我们上例中的断吉包括一种基于“等值”

16、的比较1.AST_NAME=Jones,但是SQl断言还可以包含其他几种类型的比较。其中以常用的为:等于=不等于小于大于小于或等于=大于或等于-下面给出了不是基于等值比较的一个例子:SE1.ECT4FROMEMP1.OYEESWHERESA1.ARY50000;这一查询将返回年薪高于$50,000.00的职员(参见表7)“逻辑连接符有时我们须要定义条不止一种断言的SElECT语句。举例来说,假如你仅仅想告看DaVyJoneS的信息的话,衣6中的结果将是不正确的,为了进一步定义一个WHERE子句,用户可以运用逻辑连接符AND.OR和NOT.为了只得到职员DavYJoneS的记录,用户可以俺人如下

17、语句:SE1.ECT*FROMEMP1.OYEESWHERE1.AST_NAME=JonesANDFIRST_NAME=Dav;在本例中,我们通过逻辑连接符AND将两个断言连接起来.只有两个断言都满意时整个表达式才会满意.假如用户须要定义一个SE1.ECT泄句来使得当其中任何一项成立就满意条件时,可以运用OR连接符:SE1.ECTFROMEMP1.OYEESWHERE1.AST_NAME=JonesOR1.AST_NAME=Smith;彳I时定义一个断言的最好方法是通过相反的描述来说明.假如你想要查看除了BOStOn办下处的职员以外的其他全部职员的信息时,你可以iS行如下的杳泡:SE1.ECT

18、FROMEMP1.OYEESWHERENOT(BRANCH.OFFICE=Boston);关犍字NOT后面跟者用圆括号括起来的比较表达式,其结果是对结果取否定.假如某职员所在部门的办出处在Boston,括号内的表达式返回true,但是NOT操作符将该价取反,所以该行将不被选中。断言可以与其他的阍吉嵌套运用.为了保证它们以正确的依次进行求值,可以用括号将它们括起来:SE1.ECTFROMEMP1.OYEESWHERE(1.AST_NAME=JonesANDFlRST_NAME=Indiana)OR(1.AST_NAME三Smith,ANDFIRST_NAME=Bessie);SQ1.沿用数学上标

19、准的表达式求值的约定一BII括号内的衣达式将最先进行求值,其他表达式将从左到右进行求值.以上对逻辑连接符进行了说明,在对下面的内容进行说明之前,我们再一次对SE1.ECT语句的语法进行更新:SE1.ECT(DISTINCT(column(,column)J)*FROMtable(,table)ORDERBYcolumn(ASC)(DESC,lumnA$C(DESC)11WHEREpredicate(logical-connectorpredicate);NU1.1.和三色逻辑在SQ1.中NU1.1.是一个困难的话SS,关于NU1.1.的具体描述更适合于在SQ1.的高级教程而不是现在的入门教程中

20、进行介绍.但由于NU1.1.须要进行特别处理,并且你也很可能会遇到它.所以我们还是简略地进行一下说明.首先,在斯吉中进行NUI1.推断时须要特别的语法,例如,假如用户须要显示全部年播未知的职员的全部信息,用户可以运用如下SEIECT语句:SE1.ECTFROMEMP1.OYEESWHERESA1.ARYISNU1.1.;相反,假如用户须要全部已知年薪数据的职员的信息,你可以运用以下语句:SE1.ECT*FROMEMP1.OYEESWHERESA1.ARYISNOTNU1.1.;请留意我们在列名之后运用了关键字ISNU1.1.或ISNOTNU1.1.,而不是标准的比较形武:CO1.UMN=NU1

21、.1.,Co1.UMNONUll或是逻辑操作符NoT(NU1.1.).这种形式相当简活但当你不明确地测试NUU.(而它们的确存在)时,少情会变得很混乱。例如.回过头来在我们图1中的EM-P1.OYEES表.可以看到IndianaJones的工耕等级或年薪伯播是未知的.这两个列描包含NU1.1.-可以想象运行如下的查和:SE1.ECTFROMEMP1.OYEESWHEREGRADE值。假如比较的两边都是NU1.1.,整个斯言就被认为是非确定的.将一个非确定断言取反或运用AND或OR与其他断方进行合并之后,其结果仍是非确定的.由于结果我中只包括斯言伯为直”的行,所以NU1.1.不行能满意该枚鱼,从

22、而次要运用特别的愫作符ISNU1.1.和1SNOTNU1.1.oUPDATE谱句UPDATE语句允许用户在已知的表中对现有的行进行修改.例如,我们刚刚发觉IndianaJoneS的等级为16,工资为$40,000.00,我们可以通过下面的SQ1.语句对数据库进行更新(井清除那些烦人的NU1.1.).UPDATEEMP1.OYEESSETGRADE=16,SA1.ARY=40000WHEREFIRST_NAME=IndianaAND1.AST-NAME=,Jones,;上面的例子说明白一个单行更新但是UPDATE语句可以对多行进行操作.满意WHERE条件的全部行都将被更新.黄如.你想让BoSto

23、n办事处中的全部职员搬到NeWYork你可以运用如下语句:UPDATEEMP1.OYEESSETBRANCH_OFFICE=NewYorkWHEREBRANCH.OFFICE=Boston;暇如忽视WHERE子句,表中全部行中的部门侑都将被更新为WeWYork,UPDATE语句的语法流图如卜面所示:UPDATEtableSETcolumn三value(tcolumn三valueWHEREpredicatelogical-connectorpredicate;DE1.ETE语句DElETE谙句用来捌除已知表中的行.犹如UPDArEiS句中一样.全部满意WHEREf句中条件的行都将被删除.由于S(

24、U中没有UNDo语句或是“你确认删除吗?”之类的警告,在执行这条语句时万要当心,假如确定取消IosAngeles办少处并解雇办本处的全部职员,这一卑郦的工作可以由以下这条语句来实现:DE1.ETEFROMEMP1.OYEESWHEREBRANCH.OFFICE=losAngeles;犹如UPDATE语句中一样,省略WHERE子句将使得捺作施加到我中全部的行。DE1.ETE语句的语法海图如卜面所示:DE1.ETEFROMtableWHEREpredicate(logical-connectorpredicate)j;现在我们完成了数据操作语言DM1.)的主饯语句的介绍,我们并没有对SQl能完成的全部功能进行说明,SQl.还供应了很多的功能,如求平均值、求和以及其他对表中数据的计算.此外SQ1.还能完成从多个表中进行查询(多表查询.或称之为连接)的工作“这种语言还允许你运用GRANT和REVOKE吩咐限制运用齐的数据访问权取

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 在线阅读 > 生活休闲


备案号:宁ICP备20000045号-1

经营许可证:宁B2-20210002

宁公网安备 64010402000986号