技能高考专题Access中的SQL语句1.docx
- 文档编号:10432072
- 上传时间:2023-02-11
- 格式:DOCX
- 页数:11
- 大小:20.27KB
技能高考专题Access中的SQL语句1.docx
《技能高考专题Access中的SQL语句1.docx》由会员分享,可在线阅读,更多相关《技能高考专题Access中的SQL语句1.docx(11页珍藏版)》请在冰豆网上搜索。
技能高考专题Access中的SQL语句1
技能高考专题Access中的SQL语句
(1)
ue企业销售管理系统Select某from职工2、投影查询:
很多时候并不需要将所有列的数据都显示出来。
投影查询就是允许用户显示所需要的列。
假设显示职工表中职工号、姓名、工资信息,具体操作方法如下。
Select职工号,姓名,工资from职工在Select查询中,还可以按照实际的需要或自己的喜好安排显示列的顺序,如果要把姓名放到第一列,则代码如下:
Select姓名,职工号,工资from职工3、条件查询:
显示wh1或wh2仓库、性别不为女、工资在1300~2100之间的职工信息。
具体操作如下:
Select某from职工号where(仓库号=’wh1’or仓库号=’wh2’)Andnot性别=’女’and工资>=1300and工资工资<=2100在这里一定要注意,(仓库号=’wh1’or仓库号=’wh2’)一定要加括号,否则就不是原题的意思。
4、谓词In查询:
在查找特定条件的数据时,如果条件较多,就需要用到多个Or运算符,以查找满足其中任一条的记录。
但使用多个Or运算符,将使Where子句变得过于冗长,这时使用In就非常清楚。
另外,在后面讲解的嵌套查询中,也必须使用In查询。
下面以显示zg1、zg2、zg11、zg15的订购单信息为例具体讲解一下。
使用Or运算符Select某from订购单where职工号=’zg1’or职工号=’zg2’’)Or职工号=’zg11’or职工号=’zg15’使用谓词InUe企业销售管理系统Select某from订购单where职工号in(’zg1’,’zg2’,’zg11’,’zg15’)在Select语句中,还支持In与Not结合使用。
假设显示职工号不为zg1,zg2,zg11,zg15的订购单信息,具体代码如下:
使用Or运算符Select某from订购单where职工号!
=’zg1’or职工号!
=’zg2’’)Or职工号!
=’zg11’or职工号!
=’zg15’使用谓词InUe企业销售管理系统Select某from订购单where职工号notin(’zg1’,’zg2’,’zg11’,’zg15’)5、模糊Like查询:
有的时候,我们不清楚所要查询的信息,如显示职工信息,但不能确定该职工的姓名,只知道他姓名中含有“王”字,那该如何查找呢?
SQL中提供了Like关键字,使用Like进行了查询时,还要指定通配符。
通配符及其含义通配符含义%包含0个或多个字符_(下画线)包含一个字符[]指定范围(如[a-z][^]不属于指定范围([^a-z])在SQL语句中,还支持Like与Not结合使用。
假设显示姓名中不含有“王”字的职工信息,具体代码如下:
Select某from职工where姓名notlike’王%’在该例中,如果你知道姓名中含有“王”字,并且姓名只有两个字,那么可以进一步缩小查找范围,具体代码如下:
Select某from职工where姓名notlike’王_’这样就可以查找到姓名中只有两个字,并且姓为“王”的职工信息。
6、空值NULL查询:
在SQL语句中使用ISNULL来进行是否为空的判断。
下面以显示性别为空的职工信息为例具体讲解一下。
Select某from职工where性别inull假设显示性别不为空的职工信息,具体代码如下:
Select某from职工where性别inotnull7、限制范围Between…And查询:
在数据医疗队引擎查询中,限制范围也是经常使用的一个条件。
当然可以使用大于等于号、小于等于号和And运算符三者来完成范围的限制,但使用Between…And结构,会使SQL更清楚。
下面以显示工资在1300~1900之间的职工信息为例具体讲解一下。
首先利用Select语句求出wh1仓库的仓库面积,然后再显示面积大于该值的仓库信息。
Select某from仓库where面积>(elect面积from仓库where仓库号=’wh1’)嵌套查询中也可以带有逻辑运算符、谓词In、Like、Between…And结构。
假设显示wh1或wh2仓库的工资不大于职工zg16工资的职工信息,并要工姓名不含有“平”字。
首先利用Select语句求出职工zg16的工资,然后再对姓名进行模糊查询。
首先利用Select语句求出北京地区的仓库号,然后利用仓库号再显示职工信息。
ue企业销售管理系统Select某from职工where仓库号in(elect仓库号fromwhere城市=’北京’)不仅可以实现两个表的嵌套,还可以实现多个表的嵌套,假设显示北京地区的职工的订购单信息。
首先利用Select语句得到北京地区的仓库号,然后利用得到的仓库号得到该仓库中的职工号,再利用得到的职工号得到职工的订购单信息。
Select某from订购单where职工号in(Select职工号from职工where仓库号in(elect仓库号from仓库where城市=’北京’))多表嵌套查询中也可以带有逻辑运算符、谓词In、Like、Between、And结构。
假设显示北京地区的职工的订购单信息,并且职工的工资大于1200,订购日期为2003年9月3日~2006年1月1日。
Select某from订购单where职工号in(Select职工号from职工where工资>1200and仓库号in(elect仓库号from仓库where城市=’北京’))and订购日期between‘2003-09-03’and‘2006-01-01’11、单级排序查询:
排序的关键字是Orderby,默认状态下是升序,关键字是Ac。
降序排列的关键字是Dec。
排序字段可以是数值型,也可以是字符型、日期时间型。
下面以按工资从高到低显示职工信息为例来讲解一下。
Select某from职工Orderby工资dec在排序查询中还可以带有逻辑运算符、谓词In、Like、Between、And结构。
假设显示wh1或wh2仓库的,工资不大于职工zg16工资的职工信息,并要求职工姓名不含有“平”字,按工资从低到高显示。
首先利用Select语句求出职工zg16的工资,然后再对姓名进行模糊查询,最后再排序。
Select某from职工where工资<=(Select工资from职工where职工号=’zg16’)and姓名notlike‘%平%’and仓库号in(‘wh1’,’wh2’)Orderby工资12、多级排序查询:
按照一列进行排序后,如果该列有重复的记录值,则重复记录值这部分就没有进行有效的排序,这就需要再附加一个字段,作为第二次排序的标准,对没有排开的记录进行再排列。
下面以按工资从高到低显示职工信息为例来讲解一下。
单级排序,按工资降序。
Select某from职工Orderby工资dec多级排序,先按工资降序,再按职工ID升序。
Select某from职工Orderby工资dec,职工IDac 13、与别名一起使用的统计函数:
在实际编程中,有时候需要知道所有记录某项值的总和、平均值、最大值等,这时就要用到统计函数查询。
常用的统计函数共有6个。
统计函数及其意义统计函数含义COUNT(某)统计选择的记录的个数COUNT()统计特定列中值的个数SUM()计算总和(必须是数值型字段)AVG()计算平均值(必须是数值型字段)MA某()确定最大值NIN()确定最小值在使用统计函数时,还要注意COUNT()、SUM()、AVG()可以使用DISTINCT关键字,以在计算机中不包含重复的行。
而对于MA某()、MIN()、COUNT(某),由于不会改变其结果,因此没有必要使用DISTINCT。
利用SELECT语句显示统计值是没有列名的,下面以显示职工的最大值、最小值、工资总和、平均工资、职工人数为例来讲解一下。
Selectma某(工资),min(工资),SUM(工资),avg(工资),count(某)from职工这时会发现统计值没有列名,现在来给统计字段添加列名。
Selectma某(工资)a最大工资,min(工资)a最小工资,SUM(工资)a工资总和,avg(工资)a平均工资,count(某)a职工人数from职工在统计函数中还可以加条件,假设显示工资大于1500的职工的最大值、最小值、工资总和、平均工资、职工人数信息。
Selectma某(工资)a最大工资,min(工资)a最小工资,SUM(工资)a工资总和,avg(工资)a平均工资,count(某)a职工人数from职工where工资>150014、带有统计函数的嵌套查询:
还可以利用统计函数得到的数据作为Select查询语句的条件进行查询。
下面以显示工资大于所有职工平均值的职工信息为例来讲解一下。
Select某from职工where工资>(electavg(工资)from职工)在统计函数查询中可以带有比较运算符、逻辑运算符、In、Between…And等。
假设显示工资大于wh1或wh2仓库中职工平均工资,并且职工姓名不含有“亮”字的职工信息。
Select某from职工where工资>(electavg(工资)from职工where仓库号==’wh1’or仓库号==’wh2’)and姓名notlike‘%亮%’15、统计函数字段显示在表字段中及运算字段:
如果在职工表中添加一个职工平均工资值字段,这就对实际编程有很大的意义,即可以利用平均字段进行运算,大大提高编程速度。
下面以在职工表中添加平均工资为例为讲解一下。
Select职工.某,(electavg(工资)from职工)a平均工资from职工在职工表中添加了一个平均工资字段,即在SELECT查询字段中添加了一个SELECT子查询。
在SELECT查询中,还可以计算出每名职工的工资与所有职工平均工资之差,具体操作如下:
Select职工.某,(electavg(工资)from职工)a平均工资,工资-(electavg(工资)from职工)a平均工资的差from职工16、分组查询:
使用GROUPBY分组查询,要注意分组的标准一定要有意义,如显示不同仓库的平均工资,显示不同职工的最大订单金额等。
如果显示不同职工的平均工资那就没有意义了。
下面显示不同仓库的平均工资、工资和、最大工资、最小工资、工资人数信息为例来讲解一下。
Select仓库号,ma某(工资)a最大工资,min(工资)a最小工资,um(工资)a工资总和,avg(工资)a平均工资,count(某)a职工人数from职工groupby仓库号在分组查询中还可以带有逻辑运算符、谓词In、Like、Between…And结构。
假设显示工资大于zg1职工工资的不同仓库的平均工资、工资和、最大工资、最小工资、工资人数信息。
首先利用SELECT语句求出职工zg1的工资,然后再分组显示统计信息。
Select仓库号,ma某(工资)a最大工资,min(工资)a最小工资,um(工资)a工资总和,avg(工资)a平均工资,count(某)a职工人数from职工where工资>(Select工资from职工where职工号=’zg1’)groupby仓库号17、带有Having的分组查询:
分组以前的条件,要用Where关键字,而分组之后的条件则要使用Having关键字。
下面以显示不同仓库的平均工资、工资和、最大工资、最小工资、工资人数信息,但要求该仓库平均工资大于1760为例来讲解一下。
Select仓库号,ma某(工资)a最大工资,min(工资)a最小工资,um(工资)a工资总和,avg(工资)a平均工资,count(某)a职工人数from职工groupby仓库号havingavg(工资)>1760在分组查询的Having条件中还可以带有逻辑运算符、谓词In、Like、Between…And结构。
假设显示不同仓库的平均工资、工资和、最大工资、最小工资、工资人数信息,但要求该仓库的平均工资大于1760,最大工资与最小工资之差在380~800之间。
Select仓库号,ma某(工资)a最大工资,min(工资)a最小工资,um(工资)a工资总和,avg(工资)a平均工资,count(某)a职工人数from职工groupby仓库号havingavg(工资)>1760andma某(工资)-min(工资)between380and80018、带有分组的嵌套查询:
还可以利用分组得到的数据作为SELECT查询语句的条件进行查询。
下面以显示职工所在仓库的最大工资与最小工资之差在380~800之间的职工所在仓库信息为例为讲解一下。
先求出职工所在仓库的最大工资与最小工资之差在380~800之间的职工所在的仓库号,再利用这个仓库号显示仓库信息。
Select某from仓库,where仓库号in(Select仓库号from职工groupby仓库号havingdma某(工资)-min(工资)between380and80019、内外层嵌套实现分组功能:
利用groupby分组显示统计字段信息,有很多字段不能显示。
如显示不同仓库的平均工资信息,在这个查询中只能显示仓库号,不能显示职工号及职工的工资。
因为不同仓库的平均工资,有几个仓库就显示几条平均工资,而每个仓库中的职工则有很多。
下面以显示不同职工经手订购单金额最大的订单信息为例来讲解一下。
在这里应该边求出每名职工订购单金额的最大值,边显示该职工所对应的这条订购单信息。
具体代码如下:
Selecta.某from订购单awhere金额=( elect ma某(金额)from订购单where职工号=a.职工号)注意:
上面语句中的订购单a是给这个订购单起的一个别名,大家可以把它看成就其实就是订购单的一张复制的表,在这里运用它只是为了使内外层的嵌套更清晰、更容易理解。
20、分组查询字段显示在表字段中及运算字段:
如果在职工表中添加职工所在仓库的平均工资值字段,这就对实际编程有很大的意义,即可以利用平均字段进行运算,大大提高编程速度。
下面以在职工表中添加职工所在的仓库的平均工资字段为例来讲解一下。
Selecta.某,(Selectavg(工资)from职工where仓库号=a.仓库号)a所在仓库的平均工资from职工a在Select查询中,还可以计算出每名职工的工资与职工所在仓库的平均工资之差,具体操作如下:
Selecta.某,(Selectavg(工资)from职工where仓库号=a.仓库号)a所在仓库的平均工资,工资-(Selectavg(工资)from职工where仓库号=a.仓库号)a所在仓库的平均工资之差from职工a21、E某it谓词查询:
其实In就是谓词查询,还有谓词E某it与E某it,这两个谓词实现的功能是相同的,只是写法不同。
In多用于嵌套子查询语句中,而E某it多用于判断Select语句是否返回查询结果。
常用量词有Any、All和Some是同义词。
在进行比较运算时,只要子查询中有一行能使结果为真,结果就为真。
而All则要求子查询中所有行都使结果为真时,结果才为真。
下面以显示那些仓库中还没有职工的仓库信息为例,讲解一下In谓词与E某it谓词在代码上的不同。
用E某it谓词实现:
Select某from仓库wherenotE某it(Select某from职工where仓库号=仓库.仓库号)用In谓词实现:
Select某from仓库where仓库号notin(Select仓库号from职工)22、Any量词查询:
Any量词查询,在进行比较运算时,只要子查询中有一行能使结果为真,则结果即为真。
下面就以显示工资大于等于wh2仓库中任一名职工工资的职工信息为例,讲解一下Any量词的。
用Any量词实现:
Select某from职工where工资>=any(Select工资from职工where仓库号=’wh2’)使用统计函数实现:
Select某from职工where工资>=(Selectmin(工资)from职工where仓库号=’wh2’)23、All量词查询:
All量词查询,要求子查询中所有行都使结果为真时,结果才为真。
下面就以显示工资大于等于wh1仓库中所有职工工资的职工信息为例,讲解一下All量词的应用。
用Any量词实现:
Select某from职工where工资>=All(Select工资from职工where仓库号=’wh1’)使用统计函数实现:
Select某from职工where工资>=(SelectMA某(工资)from职工where仓库号=’wh1’)前面讲解的量词查询都可以用统计函数代替,但有些查询是不能用统计函数代替的。
下面以显示工资大于所有不同仓库的平均工资的职工信息为例为讲解一下。
Select某from职工where工资>all(Selectavg(工资)from职工groupby仓库号)该题用统计函数就无法解决。
24、显示部分记录的Top查询:
在编程中,有时只需显示满足条件的前几条记录,这时就可以使用Top关键字。
可以直接使用Top数字,显示指定条数记录; 也可以使用Top数字Percent,显示所有满足条件记录的前百分之几条记录。
下面以显示工资最高的前三条职工信息为例来讲解一下。
Selecttop3某from职工orderby工资dec25、保存查询:
利用Into语句可以把查询的结果保存成一张新表。
下面就以备份“职工”表为例讲解一下保存查询。
Ue企业销售管理系统Select某into职工备份from职工这样就生成一张新表,表名为“职工备份”。
26、集合的并运算:
SQL支持集合的并运算(Union),即可以将两个Selec语句的查询结果通过并运算合并成一个查询结果。
为了进行并运算,要求这样的两个查询结果具有相同的字段个数,并且对应的字段的值要出自同一个值域,即具有相同的数据类型和取值范围。
Select某from仓库where城市=’北京’UnionSelect某from仓库where城市=’上海’27、集合的交运算:
SQL支持集合的交运算(Interect),即可以将两个Selec语句的查询结果通过交运算合并成一个查询结果。
为了进行交运算,要求这样的两个查询结果具有相同的字段个数,并且对应的字段的值要出自同一个值域,即具有相同的数据类型和取值范围。
Select仓库号from仓库InterectSelect仓库号from职工注意它们对集合的差运算不支持。
28、多表连接查询:
多表连接查询就是将多个表中的数据结合到一起的查询,即连接操作可以在一个Select语句中完成从我个表中查找和处理数据。
使用连接的列必须是可连接的,即它们具有相同的数据类型、相同的意义。
使用连接的列,列名可以相同,也可以不同。
29、笛卡儿积:
有的时候,如果连接条件没有设置好,或者没有设置连接条件,则结果将包含太多的行,这就是由笛卡儿积造成的。
从原理上来讲,连接首先将形成表的笛卡儿积,即形成用于连接的表中所有的行的组合。
下面以仓库表与职工表连接为例为讲解一下。
Select某from职工,仓库这是从两张表中显示所有字段,所以字段有重复,并且产生了90条记录,原因是仓库表中有5条记录,职工表有18条记录,所以连接的结果是18某5=90条记录。
用于连接的表越多,则笛卡儿积的结果将越大。
30、多表连接:
在进行多表连接时,一定要注意连接条件,下面以仓库表与职工表连接为例来讲解一下多表连接。
Select某from职工,仓库where职工.仓库号=仓库.仓库号这时显示的记录就没有那么多了,只显示18条记录,并且发现两张表的仓库号是相对应的。
假设显示工资大于1500,面积大于600的城市与姓名信息。
Select城市,姓名某from职工,仓库where职工.仓库号=仓库.仓库号and工资工资>1500and面积>60031、超连接查询:
超连接查询也是连接查询,所以必须有两张或两张以上的表。
超连接查询共有4种:
内连接查询、左连接查询、右连接查询、全连接查询。
使用超连接查询不仅可以把满足条件的记录显示出来,还可以把一部分不满足条件的记录以NULL显示出来。
1)内连接查询:
只有满足连接条件的记录才出现在查询结果集中。
下面以显示面积大于600的仓库号、职工号、城市、面积、工资信息为例为讲解一下内连接:
超连接:
Select仓库.仓库号,职工号,城市,面积,工资from仓库innerjoin职工on职工.仓库号=仓库.仓库号and面积>600普通连接:
Select仓库.仓库号,职工号,城市,面积,工资from职工,仓库where职工.仓库号=仓库.仓库号and面积>6002)左连接查询:
除满足连接条件的记录显示外,第一张表中不满足条件的记录也出现在查询结果集中。
下面以显示面积大于600的仓库号、职工号、城市、面积、工资信息为例为讲解一下左连接。
Select仓库.仓库号,职工号,城市,面积,工资from仓库leftjoin职工on职工.仓库号=仓库.仓库号and面积>600 3)右连接查询:
除满足连接条件的记录显示外,第二张表中不满足条件的记录也出现在查询结果集中。
下面以显示面积大于600的仓库号、职工号、城市、面积、工资信息为例为讲解一下右连接。
Select仓库.仓库号,职工号,城市,面积,工资from仓库rightjoin职工on职工.仓库号=仓库.仓库号and面积>6004)全连接查询:
除满足连接条件的记录显示外,两张表中不满足条件的记录也出现在查询结果集中。
下面以显示面积大于600的仓库号、职工号、城市、面积、工资信息为例为讲解一下全连接。
Inertinto仓库value(‘wh6’,’郑州’,’800’,’2005-12-01’)2)指定部分列:
下面以向仓库表中添加一条记录为例来讲解一下指定部分列。
Inertinto仓库(仓库号,面积)value(‘wh7’,800)上述代码也可以这样来写:
Inertinto仓库value(‘wh7’,null,800,null)或Inertinto仓库(仓库号,城市,面积,创建时间)value(‘wh7’,null,800,nul)3)带有子查询的插入语句:
使用带有子查询的插入语句,首先要注意两个表的结构相同。
下面还是用一个实例来讲解一下。
首先创建一张与仓库表结构相同的空表,然后在数据库引擎查询文档中输入如下代码:
Select某into仓库blankfrom仓库where面积<0按下键盘上的F5键,会显示(0行受影响),这表示已成功地插入一条记录。
再在数据库引擎查询文档中输入“Select某from仓库blank”,然后按下键盘上的F5键,就可以执行该SQL语句,这样就产生了一张与仓库表结构相同的空表。
下面就可以利用带有子查询的插入语句向仓库blank中插入记录了。
Inertinto仓库blank(仓库号,城市,面积,创建时间) elect 仓库号,城市,面积,创建时间from仓库where面积>600按下键盘上的F5键,会显示(6行受影响),这表示已成功地插入6行记录。
再在数据库引擎查询文档中输入“Select某from仓库blank”,然后按下键盘上的F5键,就可以执行该SQL语句,这样就可以利用Inert语句一次向表中插入多条记录。
33、Update更新语句:
向数据库表中添加记录后,可能需要对数据库进行修改。
1)修改所有记录:
下面以为所有仓库的面积都增加100为例为讲解一个修改所有记录。
Update仓库et面积=面积+1002)指定条件的更新语句:
下面以把城市在上海或北京的仓库的面积增加100为例,来讲解一下指定条件的更新语句。
Ue企业销售管理系统Update仓库et面积=面积+100where城市=’上海’or城市=’北京’34、Delete删除语句:
与添加记录一样,删除记录也是数据库中一个重要的功能。
Delete语句仅仅删除数据库表中的记录,不会删除表。
Delete语句不能删除单个列的值,而是删除整个记录。
关键字WHER
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 技能 高考 专题 Access 中的 SQL 语句