SQL查询语句讲解例子.docx
- 文档编号:18363513
- 上传时间:2023-08-16
- 格式:DOCX
- 页数:11
- 大小:19.04KB
SQL查询语句讲解例子.docx
《SQL查询语句讲解例子.docx》由会员分享,可在线阅读,更多相关《SQL查询语句讲解例子.docx(11页珍藏版)》请在冰点文库上搜索。
SQL查询语句讲解例子
SQL查询语句讲解例子
通用SQL数据库查询语句精华集2007年12月18日星期二08:
18简单的Transact-SQL查询只包括选择列表、FROM子句和WHERE子句
一、简单查询
简单的Transact-SQL查询只包括选择列表、FROM子句和WHERE子句。
它们分别说明所查询列、查询的表或视图、以及搜索条件等。
例如,下面的语句查询testtable表中姓名为“张三”的nickname字段和email字段。
SELECTnickname,emailFROMtestableWHEREname='张三'
(一)选择列表
选择列表(select_list)指出所查询列,它可以是一组列名列表、星号、表达式、变量(包括局部变量和全局变量)等构成。
1、选择所有列
例如,下面语句显示testtable表中所有列的数据:
SELECT*
FROMtesttable
2、选择部分列并指定它们的显示次序
查询结果集合中数据的排列顺序与选择列表中所指定的列名排列顺序相同。
例如:
SELECTnickname,email
FROMtesttable
3、更改列标题
在选择列表中,可重新指定列标题。
定义格式为:
列标题=列名
列名列标题
如果指定的列标题不是标准的标识符格式时,应使用引号定界符,例如,下列语句使用汉字显示列标题:
SELECT昵称=nickname,电子邮件=email
FROMtesttable
4、删除重复行
SELECT语句中使用ALL或DISTINCT选项来显示表中符合条件的所有行或删除其中重复的数据行,默认为ALL。
使用DISTINCT选项时,对于所有重复的数据行在SELECT返回的结果集合中只保留一行。
5、限制返回的行数
使用TOPn[PERCENT]选项限制返回的数据行数,TOPn说明返回n行,而TOPnPERCENT时,说明n是表示一百分数,指定返回的行数等于总行数的百分之几。
例如:
SELECTTOP2*FROMtesttableSELECTTOP20PERCENT*FROMtesttable
(二)FROM子句
FROM子句指定SELECT语句查询及与查询相关的表或视图。
在FROM子句中最多可指定256个表或视图,它们之间用逗号分隔。
在FROM子句同时指定多个表或视图时,如果选择列表中存在同名列,这时应使用对象名限定这些列所属的表或视图。
例如在usertable和citytable表中同时存在cityid列,在查询两个表中的cityid时应使用下面语句格式加以限定:
SELECTusername,citytable.cityid
FROMusertable,citytable
WHEREusertable.cityid=citytable.cityid
在FROM子句中可用以下两种格式为表或视图指定别名:
表名as别名
表名别名
例如上面语句可用表的别名格式表示为:
SELECTusername,b.cityid
FROMusertablea,citytableb
WHEREa.cityid=b.cityid
SELECT不仅能从表或视图中检索数据,它还能够从其它查询语句所返回的结果集合中查询
数据。
例如:
SELECTa.au_fname+a.au_lname
FROMauthorsa,titleauthorta
(SELECTtitle_id,title
FROMtitles
WHEREytd_sales>10000
)ASt
WHEREa.au_id=ta.au_id
ANDta.title_id=t.title_id
此例中,将SELECT返回的结果集合给予一别名t,然后再从中检索数据。
(三)使用WHERE子句设置查询条件
WHERE子句设置查询条件,过滤掉不需要的数据行。
例如下面语句查询年龄大于20的数据:
SELECT*
FROMusertable
WHEREage>20
WHERE子句可包括各种条件运算符:
比较运算符(大小比较):
>、>=、=、<、<=、<>、!
>、!
<
范围运算符(表达式值是否在指定的范围):
BETWEEN?
AND?
NOTBETWEEN…AND…
列表运算符(判断表达式是否为列表中的指定项):
IN(项1,项2?
?
)
NOTIN(项1,项2?
?
)
模式匹配符(判断值是否与指定的字符通配格式相符):
LIKE、NOTLIKE
空值判断符(判断表达式是否为空):
ISNULL、NOTISNULL
逻辑运算符(用于多条件的逻辑连接):
NOT、AND、OR
1、范围运算符例:
ageBETWEEN10AND30相当于age>=10ANDage<=30
2、列表运算符例:
countryIN('Germany','China')
3、模式匹配符例:
常用于模糊查找,它判断列值是否与指定的字符串格式相匹配。
可用于char、varchar、text、ntext、datetime和smalldatetime等类型查询。
可使用以下通配字符:
百分号%:
可匹配任意类型和长度的字符,如果是中文,请使用两个百分号即%%。
下划线_:
匹配单个任意字符,它常用来限制表达式的字符长度。
方括号[]:
指定一个字符、字符串或范围,要求所匹配对象为它们中的任一个。
[^]:
其取值也
[]相同,但它要求所匹配对象为指定字符以外的任一个字符。
例如:
限制以Publishing结尾,使用LIKE'%Publishing'
限制以A开头:
LIKE'[A]%'
限制以A开头外:
LIKE'[^A]%'
4、空值判断符例WHEREageISNULL
5、逻辑运算符:
优先级为NOT、AND、OR
(四)查询结果排序
使用ORDERBY子句对查询返回的结果按一列或多列排序。
ORDERBY子句的语法格式为:
ORDERBY{column_name[ASC|DESC]}[,…n]
其中ASC表示升序,为默认值,DESC为降序。
ORDERBY不能按ntext、text和image数据类型进行排序。
例如:
SELECT*
FROMusertable
ORDERBYagedesc,useridASC
另外,可以根据表达式进行排序。
二、联合查询
UNION运算符可以将两个或两个以上上SELECT语句的查询结果集合合并成一个结果集合显示,即执行联合查询。
UNION的语法格式为:
select_statement
UNION[ALL]selectstatement
[UNION[ALL]selectstatement][…n]
其中selectstatement为待联合的SELECT查询语句。
ALL选项表示将所有行合并到结果集合中。
不指定该项时,被联合查询结果集合中的重复行将只保留一行。
联合查询时,查询结果的列标题为第一个查询语句的列标题。
因此,要定义列标题必须在第一个查询语句中定义。
要对联合查询结果排序时,也必须使用第一查询语句中的列名、列标题或者列序号。
在使用UNION运算符时,应保证每个联合查询语句的选择列表中有相同数量的表达式,并且每个查询选择表达式应具有相同的数据类型,或是可以自动将它们转换为相同的数据类型。
在自动转换时,对于数值类型,系统将低精度的数据类型转换为高精度的数据类型。
在包括多个查询的UNION语句中,其执行顺序是自左至右,使用括号可以改变这一执行顺序。
例如:
查询1UNION(查询2UNION查询3)
三、连接查询
通过连接运算符可以实现多个表查询。
连接是关系数据库模型的主要特点,也是它区别于其它类型数据库管理系统的一个标志。
在关系数据库管理系统中,表建立时各数据之间的关系不必确定,常把一个实体的所有信息存放在一个表中。
当检索数据时,通过连接操作查询出存放在多个表中的不同实体的信息。
连接操作给用户带来很大的灵活性,他们可以在任何时候增加新的数据类型。
为不同实体创建新的表,尔后通过连接进行查询。
SQL查询语句例子
数据表的查询(select)
select字段列表[as别名],*from数据表名
[where条件语句]
[groupby分组字段]
[orderby排序字段列表desc]
[LIMITstartrow,rownumber]
1、Select字段列表From数据表
例:
①、selectid,gsmc,add,telfromhaf(*表示数据表中所有字段)②、select单价,数量,单价*数量as合计金额fromhaf(As设置字段的别名)
2、Select…from…Where筛选条件式
筛选条件式:
①、字符串数据:
select*from成绩单Where姓名='李明'
②、万用字符:
select*from成绩单Where姓名like'李%'select*from成绩单Where姓名like'%李%'
select*from成绩单Where姓名like'%李_'
③、特殊的条件式:
⑴=/>/<>/>=/<=
⑵AND(逻辑与)OR(逻辑或)NOT(逻辑非)
⑶Where字段名称in(值一,值二)
⑷Where字段名称IsNull/Where字段名称IsNotNull
3、Select…from…groupby字段
SQL函数:
SELECTsex,count(id)aswomenfrom`user`groupby'sex';函数名描述函数名描述
AVG平均值Count计数
MAX最大值MIN最小值
Sum求和
4、Select…from…Orderby字段列表desc(倒,如果直接写为顺序)
5、Select…from…LIMIT".$start_rowno.",".($pagesize+1)
第二节SQL语句实例应用
数据库说明:
student(学生表):
stdidint(11)id号
son5)学号
sname20)姓名
ssextinyint
(1)性别
sage3)年龄
sdept20)所在系
course(课程表):
couidint(11)id号
cno5)课程号
cname20)课程名
cpno6)选修课号
ccredit50)学分
sc(学生选课表):
scidint(11)id号
cno5)课程号
gradefloat成绩
sno5)学号
单表查询:
一、选择表中的若干字段:
查询指定列:
1、查询全体学生的学号与姓名;
selectson,snamefromstudent
2、查询全体学生的姓名、学号、所在系;
selectsname,son,sdeptfromstudent
3、查询全体学生的详细记录;
select*fromstudent
查询经过计算的值:
4、查全体学生的姓名及其出生年份
selectsname,year(now())-sageas'出生年份'fromstudent
5、查询全体学生的姓名、出生年份和所有系,要求用大(小)写字母表示所有系名
selectsnameas'姓名','出生与',year(now())-sageas'出生年份',UPPER(sdept)as'系别'fromstudent
selectsnameas'姓名','出生与',year(now())-sageas'出生年份',lower(sdept)as'系别'fromstudent
二、选择表中的若干记录:
消除取值重复的行:
6、查询选修了课程的学生学号
selectdistinctsnofromsc
查询满足条件的记录:
比较大小:
7、查询计算机全体学生的名单
selectsnamefromstudentwheresdept='cs'
8、查询所有年龄在20岁以下的学生姓名及其年龄
selectsname,sagefromstudentwheresage<20
9、查询考试成绩小于90分的学生的学号
selectdistinctsnofromscwheregrade<90
确定范围:
10、查询年龄在18-20岁之间的学生的姓名、系别和年龄。
selectsname,sdept,sagefromstudentwheresagebetween18and20
11、查询年龄不在19-20岁之间的学生的姓名、系别和年龄。
selectsname,sdept,sagefromstudentwheresagenotbetween19and20
确定集合:
12、查询信息系(is)、数学系(ma)和计算机科学系(cs)学生的姓名和性别。
selectsname,ssexfromstudentwheresdeptin('is','ma','cs')
13、查询不是信息系(is)、数学系(ma)的学生的.姓名、系别和年龄。
selectsname,ssexfromstudentwheresdeptnotin('is','ma')
字符匹配(like'<匹配串>'%代表任意长度(长度可以为0)的字符串;_代表任意单个字符,汉字得用两个"__"):
14、查询学号为95001的学生的详细情况
select*fromstudentwheresonlike'95001'
15、查询所有姓名李的学生的姓名、学号和性别。
selectsname,son,ssexfromstudentwheresnamelike'李%'
16、查询姓名是两个字学生的姓名、学号和性别。
selectsname,son,ssexfromstudentwheresnamelike'____'
17、查询所有不姓李的学生姓名。
selectsnamefromstudentwheresnamenotlike'李__'
涉及空值的查询:
18、某些学生选修课程后没有参加考试,所以有选课记录,但没有考试成绩,查询缺少成绩的学生的学号和相应的课程号。
selectsno,cnofromscwheregradeisnull
19、查询所有有成绩的学生学号和课程号。
selectsno,cnofromscwheregradeisnotnull
多重条件查询(andor):
20、查询计算机系年龄在20岁的学生姓名。
selectsnamefromstudentwheresdept='cs'andsage=20
21、查询信息系(is)、数学系(ma)和计算机科学系(cs)学生的姓名和性别。
selectsname,ssexfromstudentwheresdept='is'orsdept='ma'orsdept='cs'
三、对查询结果排序:
22、查询选修了3号课程的学生的学号及其成绩,查询结果按分数的降序排列。
selectsno,gradefromscwherecno='3'orderbygradedesc
23、查询全体学生情况,查询结果按所在系的系号升序排列,同一系中的学生按年龄降序排列。
select*fromstudentorderbysdept,sagedesc
四、使用集函数:
24、查询学生总人数。
selectcount(*)as'总人数'fromstudent
25、查询选修了课程的学生人数。
selectcount(distinctsno)as'人数'fromsc
26、计算1号课程的学生平均成绩
selectformat(avg(grade),2)as'平均成绩'fromscwherecno='1'
27、查询选修1号课程的学生最高分数。
selectmax(grade)fromscwherecno='1'
五、对查询结果分组:
28、求各个课程号及相应的选课人数。
selectcnoas'课程号',count(sno)as'人数'fromscgroupbycno
29、查询选修了3门以上课程的学生学号。
selectsnofromscgroupbysnohavingcount(*)>2
注:
where子句与having短语的区别在于作用对象不同,where子句作用于基本表或视图,从中选择满足条件的记录,having短语作用于组,从中选择满足条件的组。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- SQL 查询 语句 讲解 例子