知识点、SQL语句学习及详细总结
SQl数据库快速入门必须掌握的四大基本语句

SQl数据库快速入门必须掌握的四大基本语句做一个系统的后台,基本上都少不了增删改查,作为一个新手入门,我们必须要掌握SQL 四条最基本的数据操作语句:Insert,Select,Update和Delete!下面对这四个语句进行详细的剖析:熟练掌握SQL是数据库用户的宝贵财富。
在本文中,我们将引导你掌握四条最基本的数据操作语句—SQL的核心功能—来依次介绍比较操作符、选择断言以及三值逻辑。
当你完成这些学习后,显然你已经开始算是真正SQ L入门了。
在我们开始之前,先使用CREA TE TABLE语句来创建一个表。
DDL语句对数据库对象如表、列和视进行定义。
它们并不对表中的行进行处理,这是因为DDL语句并不处理数据库中实际的数据。
这些工作由另一类SQL语句—数据操作语言(DML)语句进行处理。
SQL中有四种基本的DML操作:INSERT,SELECT,UPDATE和DELETE。
由于这是大多数SQL用户经常用到的,我们有必要在此对它们进行一一说明。
在图1中我们给出了一个名为EMPLOY EES的表。
其中的每一行对应一个特定的雇员记录。
请熟悉这张表,我们在后面的例子中将要用到它。
INSERT语句用户可以用IN S ERT语句将一行记录插入到指定的一个表中。
例如,要将雇员John Smith 的记录插入到本例的表中,可以使用如下语句:INSERTINTO EMPLOYE ES VALUES('Smith','John','1980-06-10','Los Angles',16,45000);通过这样的IN SERT语句,系统将试着将这些值填入到相应的列中。
这些列按照我们创建表时定义的顺序排列。
SQL语言学习总结

SQL语言学习总结1. SQL(Structured Query Language)是一种用于管理关系数据库系统的标准语言。
通过SQL语句可以对数据库进行创建、查询、修改和删除等操作。
2. SQL语句主要分为四种类型:数据操作语言(DML),数据定义语言(DDL),数据控制语言(DCL)和事务控制语言(TCL)。
3. 数据操作语言(DML)主要用于对数据库中的数据进行查询和修改操作,常用的DML语句有SELECT、INSERT、UPDATE和DELETE。
4. 数据定义语言(DDL)用于定义数据库结构,包括创建表、修改表和删除表等操作,常用的DDL语句有CREATE、ALTER和DROP。
5. 数据控制语言(DCL)用于设置数据库用户的权限和角色,常用的DCL语句有GRANT和REVOKE。
6. 事务控制语言(TCL)用于管理数据库事务,常用的TCL语句有COMMIT、ROLLBACK和SAVEPOINT。
7. SQL语句可以通过执行顺序分为两种类型:批处理SQL和交互式SQL。
批处理SQL 一次执行多条SQL语句,而交互式SQL是一次执行一条SQL语句。
8. SQL语句可以使用通配符、操作符和函数来进行数据查询和处理。
通配符可以用来匹配模式,操作符用于比较和计算,函数用于处理数据和返回结果。
9. SQL语句可以使用条件语句和连接语句来进行复杂的数据查询和更新操作。
条件语句用于筛选数据,连接语句用于联结多个表进行查询。
10. 使用索引可以提高数据库的查询性能,可以通过创建索引来加快查询速度。
索引可以使用CREATE INDEX语句创建,也可以通过ALTER TABLE语句添加。
总的来说,学习SQL语言需要熟悉常用的语法、理解不同类型的SQL语句的用途和使用场景,并通过实践和练习来加强对SQL语言的理解和应用能力。
全国计算机二级sql知识点

全国计算机二级sql知识点
全国计算机二级SQL的知识点包括但不限于:
1. SQL的数据定义语言(DDL),如CREATE、ALTER、DROP等命令,用于定义和管理数据库中的表、视图、索引等对象。
2. SQL的数据操纵语言(DML),如INSERT、UPDATE、DELETE等命令,用于添加、修改、删除数据库中的数据。
3. SQL的数据查询语言(DQL),如SELECT命令,用于查询数据库中的数据,可以进行条件查询、聚合查询、连接查询等操作。
4. SQL的数据控制语言(DCL),如GRANT、REVOKE等命令,用于控制数据库中的数据访问权限。
5. 数据库规范化理论,包括第一范式(1NF)、第二范式(2NF)、第三范式(3NF)等,用于规范化数据库表的设计,消除数据冗余和提高数据一致性。
6. 数据库设计的基本概念和方法,如ER图、实体-关系模型等,用于设计数据库结构和数据关系。
7. 数据库的备份与恢复技术,如备份数据库文件、恢复数据库文件等,用于保护数据库的数据安全和完整性。
8. 数据库的性能优化技术,如索引优化、查询优化等,用于提高数据库性能和响应时间。
9. 数据库的安全性管理,如用户账户管理、权限控制等,用于保护数据库的安全和机密信息。
以上是全国计算机二级SQL知识点的一部分,仅供参考。
具体考
试内容和要求可能因地区和考试机构而有所不同,建议查阅相关的考试大纲和教材。
菜鸟教程sql语法

菜鸟教程sql语法标题:深入理解SQL语法:从入门到精通导语:SQL(Structured Query Language)是一种用于管理和操作关系型数据库的编程语言,广泛应用于各行各业的数据存储与查询。
本文将带你深入了解SQL语法,在掌握基本语法的同时,为你提供全面而有指导意义的内容。
让我们开始SQL之旅吧!一、SQL简介及基本语法1. SQL的概念与作用SQL是一门标准化语言,用于管理和操作关系型数据库。
它可以帮助我们存储、查询、更新、删除数据库中的数据,是使得数据库具备强大功能的基石。
2. SQL基本语法SQL语句通常包括以下几个部分:- SELECT:用于查询数据库中的数据。
- INSERT INTO:用于向数据库插入新数据。
- UPDATE:用于更新数据库中的数据。
- DELETE:用于删除数据库中的数据。
- CREATE TABLE:用于创建数据库表。
- ALTER TABLE:用于修改数据库表结构。
- DROP TABLE:用于删除数据库表。
- WHERE语句:用于指定查询或更新条件。
二、SQL数据查询与操作1. 数据查询SQL语句的核心部分是SELECT语句,可以通过以下方式查询数据:- 使用通配符(*)查询所有字段。
- 通过指定字段名查询特定字段。
- 使用WHERE语句添加查询条件。
- 使用ORDER BY语句进行排序。
- 使用LIMIT语句限制查询结果数量。
2. 数据操作- INSERT INTO语句用于向数据库表中插入新数据。
- UPDATE语句用于更新已存在的数据。
- DELETE语句用于删除数据库中的数据。
三、SQL表的创建与修改1. 创建表使用CREATE TABLE语句可以创建数据库中的新表。
需要指定表名及其字段名、字段类型和约束等信息。
2. 修改表结构- 使用ALTER TABLE语句可以对现有表结构进行修改,例如添加字段、修改字段类型或长度等。
- 使用DROP TABLE语句可以删除数据库中的表。
初学者必读的SQL数据库基础教程

初学者必读的SQL数据库基础教程SQL数据库是一种常用的数据库管理系统,广泛应用于各种软件开发和数据管理领域。
对于初学者来说,掌握SQL数据库的基础知识是非常重要的。
本文将从数据定义语言、数据操作语言、数据查询语言和数据控制语言等方面,为初学者提供一份必读的SQL数据库基础教程。
第一章数据定义语言(DDL)数据定义语言(DDL)是SQL数据库中用来定义数据库结构的语言。
它包括创建、修改和删除数据库、表、列以及其他对象的操作。
在SQL中,创建数据库使用CREATE DATABASE语句,创建表使用CREATE TABLE语句,修改表结构使用ALTER TABLE语句,删除表使用DROP TABLE语句等。
初学者在学习时应该了解这些常用的DDL语句,并能够正确地使用它们。
第二章数据操作语言(DML)数据操作语言(DML)是SQL数据库中用来对数据库中的数据进行操作的语言。
它包括插入、更新和删除数据的操作。
在SQL中,插入数据使用INSERT INTO语句,更新数据使用UPDATE语句,删除数据使用DELETE FROM语句等。
初学者需要熟悉这些基本的DML语句,并能够通过它们来操作数据库中的数据。
第三章数据查询语言(DQL)数据查询语言(DQL)是SQL数据库中用来查询数据库中的数据的语言。
它包括SELECT语句和一些用于过滤、排序和聚合数据的函数。
初学者需要掌握SELECT语句的基本用法,了解如何使用WHERE子句进行条件过滤,如何使用ORDER BY子句进行排序,以及如何使用GROUP BY子句进行数据聚合。
第四章数据控制语言(DCL)数据控制语言(DCL)是SQL数据库中用来控制数据库访问权限和事务处理的语言。
它包括GRANT和REVOKE语句用于授权和撤销权限,以及BEGIN TRANSACTION、COMMIT和ROLLBACK语句用于管理事务。
初学者需要了解如何使用DCL语句来管理数据库的安全性和事务一致性。
sql语句大全及用法

sql语句大全及用法SQL(Structured Query Language,结构化查询语言)是用于存取和操纵关系式数据库的标准计算机语言,可用于定义、检索以及控制数据库中的数据。
它是由IBM公司的研究员开发出来的,不久后普及全世界,大大提高了操作数据库的效率。
sql通常被分成两种:DDL(数据定义语言,Data Definition Language)和DML(数据库操纵语言,Data Manipulation Language)。
其中DDL用于定义数据库结构和构建表,而DML则用于操纵并操作数据库中的数据。
1. 数据库结构构建(DDL)• 创建表(Create):CREATE TABLE 表名(字段名1 数据类型,字段名2 数据类型,……)• 修改表(Alter):ALTER TABLE 表名 ADD 字段名数据类型;ALTER TABLE 表名DROP 字段名;ALTER TABLE 表名 MODIFY 字段名数据类型• 删除表(Drop):DROP TABLE 表名2. 数据操纵(DML)• 更新数据(Update):UPDATE 表名 SET 字段名= 值 WHERE 条件• 授权(Grant):GRANT 权限 ON 数据库名 TO 用户4. 高级SQL语句• 嵌套查询(Nested query):SELECT * FROM 表名 WHERE 字段名 IN(SELECT * FROM 另一个表名 WHERE 条件)• 分组聚合(Group by):SELECT 字段名 FROM 表名 GROUP BY 字段名• 分页查询(Page query):SELECT * FROM 表名 LIMIT 起始的记录条数,获取的记录数。
SQL定义变量、创建表及重点掌握知识点(一)

SQL定义变量、创建表及重点掌握知识点(一)一、定义变量、赋值1定义一个变量a 设置初始值并输出declare@a intset@a=5print@a–输出5如下图2使用select语句赋值declare@user1nvarchar(50) --变量及类型select@user1='测试注意标点符号'print@user1declare@user2nvarchar(50)select@user2= Name from table_User where ID=1 --把select 查询的结果给user2,当然要先table_User表要先建立好print@user2declare @user1 nvarchar(50)select @user1=(select name from daotestnot where name='hu')print @user13使用update语句赋值declare@user3nvarchar(50)update table_User set@user3= Name where ID=1print@user3二、建表、临时表、表变量1创建临时表1create table #table_User([ID][int]NOT NULL,[Oid][int]NOT NULL,[Login][nvarchar](50) NOT NULL,[Rtx][nvarchar](4) NOT NULL,[Name][nvarchar](5) NOT NULL,[Password][nvarchar](max) NULL,[State][nvarchar](8) NOT NULL);2向临时表1插入一条记录依次填写表中数据insert into #table_User (ID,Oid,[Login],Rtx,Name,[Password],State) values (1,2,'LS','0000','临时','888','状态');--从ST_User查询数据,填充至新生成的临时表select*into #DU_User2 from ST_User where ID<8--查询并联合两临时表select*from #DU_User2 where ID<3union select*from #DU_User1--删除两临时表drop table #DU_User1drop table #DU_User2--创建临时表CREATE TABLE #t([ID][int]NOT NULL,[Oid][int]NOT NULL,[Login][nvarchar](50) NOT NULL,[Rtx][nvarchar](4) NOT NULL,[Name][nvarchar](5) NOT NULL,[Password][nvarchar](max) NULL,[State][nvarchar](8) NOT NULL,)--将查询结果集(多条数据)插入临时表insert into #t select*from ST_User--不能这样插入--select * into #t from dbo.ST_User--添加一列,为int型自增长子段alter table #t add[myid]int NOT NULL IDENTITY(1,1)--添加一列,默认填充全球唯一标识alter table #t add[myid1]uniqueidentifier NOT NULL default(newid())select*from #tdrop table #t--给查询结果集增加自增长列--无主键时:select IDENTITY(int,1,1)as ID, Name,[Login],[Password]into #t from ST_User select*from #t--有主键时:select (select SUM(1) from ST_User where ID<= a.ID) as myID,*from ST_User a order by myID--定义表变量declare@t table(id int not null,msg nvarchar(50) null)insert into@t values(1,'1')insert into@t values(2,'2')select*from@t三、循环--while循环计算1到100的和declare@a intdeclare@sum intset@a=1set@sum=0while@a<=100beginset@sum+=@aset@a+=1endprint@sum四、条件语句--if,else条件分支if(1+1=2)beginprint'对'endelsebeginprint'错'end--when then条件分支declare@today intdeclare@week nvarchar(3)set@today=3set@week=casewhen@today=1then'星期一'when@today=2then'星期二'when@today=3then'星期三'when@today=4then'星期四'when@today=5then'星期五'when@today=6then'星期六'when@today=7then'星期日'else'值错误'endprint@week五、游标declare@ID intdeclare@Oid intdeclare@Login varchar(50)--定义一个游标declare user_cur cursor for select ID,Oid,[Login]from ST_User --打开游标open user_curwhile@@fetch_status=0begin--读取游标fetch next from user_cur into@ID,@Oid,@Loginprint@ID--print @Loginendclose user_cur--摧毁游标deallocate user_cur六、触发器触发器中的临时表:Inserted存放进行insert和update 操作后的数据Deleted存放进行delete 和update操作前的数据--创建触发器Create trigger User_OnUpdateOn ST_Userfor UpdateAsdeclare@msg nvarchar(50)--@msg记录修改情况select@msg= N'姓名从“'+ + N'”修改为“'+ +'”' from Inserted,Deleted--插入日志表insert into[LOG](MSG)values(@msg)--删除触发器drop trigger User_OnUpdate七、存储过程--创建带output参数的存储过程CREATE PROCEDURE PR_Sum@a int,@b int,@sum int outputASBEGINset@sum=@a+@bEND--创建Return返回值存储过程CREATE PROCEDURE PR_Sum2@a int,@b intBEGINReturn@a+@bEND--执行存储过程获取output型返回值declare@mysum intexecute PR_Sum 1,2,@mysum outputprint@mysum--执行存储过程获取Return型返回值declare@mysum2intexecute@mysum2= PR_Sum2 1,2print@mysum2八、自定义函数函数的分类:1)标量值函数2)表值函数a:内联表值函数b:多语句表值函数3)系统函数--新建标量值函数create function FUNC_Sum1(@a int,@b int)returns intasbeginreturn@a+@bend--新建内联表值函数create function FUNC_UserTab_1(@myId int)returns tableasreturn (select*from ST_User where ID<@myId)--新建多语句表值函数create function FUNC_UserTab_2(@myId int)returns@t table([ID][int]NOT NULL,[Oid][int]NOT NULL,[Login][nvarchar](50) NOT NULL,[Rtx][nvarchar](4) NOT NULL,[Name][nvarchar](5) NOT NULL,[Password][nvarchar](max) NULL,[State][nvarchar](8) NOT NULL)asbegininsert into@t select*from ST_User where ID<@myId returnend--调用表值函数select*from dbo.FUNC_UserTab_1(15)--调用标量值函数declare@s intset@s=dbo.FUNC_Sum1(100,50)print@s--删除标量值函数drop function FUNC_Sum1谈谈自定义函数与存储过程的区别:一、自定义函数:1. 可以返回表变量2. 限制颇多,包括不能使用output参数;不能用临时表;函数内部的操作不能影响到外部环境;不能通过select返回结果集;不能update,delete,数据库表;3. 必须return 一个标量值或表变量自定义函数一般用在复用度高,功能简单单一,争对性强的地方。
sql 语句简易教程

sql 语句简易教程SQL语句简易教程1. 什么是SQL•SQL全称为Structured Query Language(结构化查询语言)•是一种用于管理关系型数据库的语言•可以使用SQL语句对数据库进行查询、插入、更新和删除操作2. SQL语句的基本结构•SQL语句由关键字、表名、字段、条件等组成•常见的SQL语句包括:SELECT、INSERT、UPDATE和DELETE SELECT语句•用于从数据库中查询数据•示例:SELECT * FROM 表名;SELECT 列名1, 列名2, ... FROM 表名;INSERT语句•用于向数据库中插入新数据•示例:INSERT INTO 表名 (列1, 列2, ...) VALUES (值1, 值2, ...);UPDATE语句•用于更新数据库中的现有数据•示例:UPDATE 表名 SET 列1 = 值1, 列2 = 值2 WHERE 条件; DELETE语句•用于从数据库中删除数据•示例:DELETE FROM 表名 WHERE 条件;3. SQL语句中的常见条件•条件用于过滤查询结果•常见的条件操作符有:=、<>、<、>、<=、>=等AND条件•用于同时满足多个条件•示例:SELECT * FROM 表名 WHERE 条件1 AND 条件2;OR条件•用于满足多个条件中的任意一个•示例:SELECT * FROM 表名 WHERE 条件1 OR 条件2;IN条件•用于指定某个字段的值在一组值中•示例:SELECT * FROM 表名 WHERE 列名 IN (值1, 值2, ...); LIKE条件•用于模糊匹配•示例:SELECT * FROM 表名 WHERE 列名 LIKE '关键词%';4. SQL语句中的常见操作排序•可以使用ORDER BY子句对查询结果进行排序•示例:SELECT * FROM 表名 ORDER BY 列名 ASC/DESC;分页•可以使用LIMIT子句对查询结果进行分页•示例:SELECT * FROM 表名 LIMIT 偏移量, 数量;聚合•可以使用聚合函数(如SUM、COUNT、AVG、MIN和MAX)对查询结果进行统计•示例:SELECT COUNT(*) FROM 表名;SELECT SUM(列名) FROM 表名;5. SQL语句的进阶用法•SQL语句还支持表连接、子查询、视图、索引等高级用法•可以进一步学习和探索这些用法以更好地应对复杂的数据操作需求以上是关于SQL语句简易教程的详细整理,希望对你学习SQL有所帮助。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
一. 数据库简介和创建1. 系统数据库在安装好SQL SERVER后,系统会自动安装5个用于维护系统正常运行的系统数据库:(1)master:记录了SQL SERVER实例的所有系统级消息,包括实例范围的元数据(如登录帐号)、端点、链接服务器和系统配置设置。
(2)msdb:供SQL SERVER 代理服务调度报警和作业以及记录操作员的使用,保存关于调度报警、作业、操作员等信息。
(备份还原时)(3)model:SQL SERVER 实例上创建的所有数据库的模板。
(4)tempdb:临时数据库,用于保存临时对象或中间结果集,为数据库的排列等操作提供一个临时工作空间。
(每次启动都会重新创建)(5)Resource:一个只读数据库,包含了SQL SERVER 的所有系统对象。
(隐藏的数据库)2. 数据库的组成2.1 数据文件(1)主要数据文件:扩展名为 .mdf ,每个数据库有且只能有一个。
(2)次要数据文件:扩展名为 .ndf ,可以没有或有多个。
2.2 日志文件扩展名为 .ldf ,用于存放恢复数据库的所有日志信息。
2.3 数据的存储分配(1)数据文件和日志文件的默认存放位置为:\Programe Files\Microsoft SQL Server\MSSQL.1\MSSQL\Data文件夹。
(2)数据的存储分配单位是数据页。
一页表是一块8KB的连续磁盘空间。
(3)页是存储数据的最小空间分配单位,页的大小决定了数据库表中一行数据的最大大小。
3. SQL语句数据库操作(1)创建数据库CREATE DATABASE database_name二. SQL基础SQL(Structured Query Language,结构化查询语言)是用户操作关系数据库的通用语言。
1. SQL功能概述2. 系统提供的数据类型2.1 数值数据类型2.2 普通编码字符串类型char 和varchar的区别:若某列数据类型为varchar(20),存字符串”Jone”时,只占用4个字节,而char (20)会在为填满的空间中填写空格。
所以, varchar类型比char类型更节省空间,但它的开销会大一些,处理速度也慢一些。
因此,n值比较小(小于4),用char类型更好些。
2.3 统一编码字符串类型(Unicode)三. SQL数据操作语言1.数据查询语句1.1 查询语句的基本结构SELECT <目标列名序列> --需要哪些列From <表名> --来自哪张表[WHERE <行选择条件>][GROUP BY <分组依据列>][HAVING <组>][ORDER BY <排序依据列>]SELECT子句用于指定输出的字段;FROM子句用于指定数据的来源;WHERE子句用于指定数据的选择条件;GROUP BY子句用于对检索到的记录进行分组;HAVING 子句用于指定组的选择条件;ORDER BY 子句用于对查询的结果进行排序;以上子句中,SELECT 子句和FROM子句是必需的,其它是可选的。
1.2 单表查询1.2.1选择表中若干列(1)查询指定的列SELECT列名FROM表名例子:SELECT Sname,Sno FROM Student(2)查询全部列SELECT * FROM表名例子:SELECT * FROM Student(3)查询经过计算的列SELECT列名FROM表名例子:SELECT Sname,year(getdata()) - year(Birthdate) FROM Student 1.2.2 选择表中的若干元祖(1)消除取值相同的行:DISTINCTSELECT DISTINCT Sno FROM表名例子:SELECT DISTINCT Sno FROM Student(2)查询满足条件的元祖a.比较大小例子:SELECT Sname FROM Student WHERE year(getdata()) - year(Birthdate) < 20b.确定范围BETWEEN…AND 和NOT BETWEEN…AND可用于查找属性值在或不在指定范围。
列名 | 表达式 | [NOT] BETWEEN 下限值AND上限值BETWEEN…AND代表的范围是在上限值和下限值之间(包括边界值),即为true。
NOT BETWEEN…AND代表的范围是不在上限值和下限值之间(不包括边界值),即为true。
(若判断值为边界值时,为false)例子:SELECT Sno,Cno FROM SC WHERE Grade BETWEEN 80 AND 90此查询等价于:SELECT Sno,Cno FROM SC WHERE Grade >= 80 AND Grade <= 90例子:SELECT Sno,Cno FROM SC WHERE Grade NOT BETWEEN 80 AND 90此查询等价于:SELECT Sno,Cno FROM SC WHERE Grade < 80 OR Grade > 90c. 确定集合IN运算符的含义:当列中的值和集合中的某个常量值相等时,结果为True。
NOT IN运算符的含义:当列中的值和集合中的全部常量值都不相等时,结果为True。
例子:SELECT Sno FROM Student WHERE Dept IN ('信息管理系','计算机系')此查询等价于:SELECT Sno FROM Student WHERE Dept = '信息管理系' OR Dept = '计算机系')例子:SELECT Sno FROM Student WHERE Dept NOT IN ('信息管理系','计算机系')此查询等价于:SELECT Sno FROM Student WHERE Dept != '信息管理系' AND Dept != '计算机系')d. 字符串匹配Like运算符用于查找指定列中与匹配串匹配的元祖。
列名 [NOT] LIKE <匹配串>例子:(查询姓“张”的学生详细信息)SELECT * FROM Student WHERE Sname LIKE'张%'(查询不姓“张”的学生详细信息)SELECT * FROM Student WHERE Sname NOT LIKE'张%'(查询姓“张”、“李”的学生详细信息)SELECT * FROM Student WHERE Sname LIKE'[张李]%'(查询名字的第二个字为“小” 或“大”的学生详细信息)SELECT * FROM Student WHERE Sname LIKE'_[小大]%'e. 涉及空值的查询空值(NULL)在数据库中有特殊含义,表示当前不确定或未知的值。
判断是否为NULL时,不可用普通的比较运算符,需用IS NULL例子:SELECT Sno FROM Student WHERE Grade IS NULL1.2.3 对查询结果进行排序将查询结果按照指定的顺序显示。
ASC表示按列值升序排列(从上往下,值从大到小)。
DESC表示按列值降序排列(从上往下,值从小到大)。
默认为ASC。
ORDER BY <列名> [ASC|DESC]例子:SELECT Sno,Grade FROM SC ORDER BY Grade DESC1.2.4 使用聚合函数统计数据聚合函数也称为统计函数或集合函数,作用是对一组值进行计算并返回一个统计结果。
上述函数除COUNT(*) 外,其它函数在计算过程中均忽略NULL值(统计学生总人数)SELECT COUNT(*) FROM Student(统计“001”学号学生的考试平均成绩)SELECT AVG(Grade) FROM SC WHERE Sno = '001'(查询“C001”号课程考试成绩的最高分和最低分)SELECT MAX(Grade) 最高分,MIN(Grade) 最低分FROM SC WHERE Cno = 'C001'聚合函数不能出现在WHERE子句中!1.2.5 对数据进行分组统计需要先对数据进行分组,然后再对每个组进行统计。
分组子句GROUP BY。
在一个查询语句中,可以用多个列进行分组。
分组子句跟在WHERE子句的后面:GROUP BY<分组依据列>[,...n][HAVING <组筛选条件>](1)使用GROUP BY 子句(统计每门课程的选课人数,列出课程号和选课人数)SELECT Cno as课程号, COUNT(Sno) as选课人数From SC Group BY Cno(统计每个学生的选课门数和平均成绩)SELECT Sno 学号, COUNT(*) 选课门数,AVG(Grade) 平均成绩 From SC Group BY S no带WHERE子句的分组(统计每个系的女生人数)SELECT Dept, COUNT(*)女生人数From Student Where Sex = '女'Group BY Dep t(2)使用HAVING 子句HAVING子句用于对分组后的统计结果再进行筛选,它的功能与WHERE子句类似,它用于组而不是单个记录。
在HAVING子句中可以使用聚合函数,但在WHERE子句中不能,通常与GROUP子句一起使用。
(查询选课门数超过3门的学生的学号和选课门数)SELECT Sno 学号, COUNT(*) 选课门数,AVG(Grade) 平均成绩 From SC Group BY S no HAVING COUNT(*) > 3(3)WHERE 、GROUP BY 、HAVING 的作用及执行顺序•WHERE子句用于筛选FROM子句中指定的数据所产生的行数据。
•GROUP BY子句用于对经WHERE子句筛选后的结果数据进行分组。
•HAVING子句用于对分组后的统计结果再进行筛选。
可以分组操作之前应用的筛选条件,在WHERE子句中指定它们更有效,这样可以减少参与分组的数据行。
在HAVING子句中指定的筛选条件应该是那些必须在执行分组操作之后应用的筛选条件。
(查询计算机系和信息管理系每个系的学生人数)第一种:SELECT Dept,COUNT(*) FROM Student GROUP BY Dept Having Dept in('计算机系','信息管理系')第二种:SELECT Dept,COUNT(*) FROM Student WHERE Dept in ('计算机系','信息管理系')G ROUP BY Dept以上例子比较:第一种是按照系分组好了之后,只采取所有系中的两个系,显然效率不高。