文档详情

第5章SQL与视图-.ppt

发布:2017-04-24约2.88千字共45页下载文档
文本预览下载声明
数据库及其应用;本章学习目标与要求;5.1 SQL概述;5.2 SQL定义功能 5.2.1 数据库的定义与删除;1、表的定义: SQL表定义命令可以定义数据库表和自由表. CREATE TABLE | DBF表名1[NAME长表名][FREE] (字段名1字段类型[(字段宽度[,小数位数])][NULL | NOT NULL] [CHECK逻辑表达式1[ERROR出错提示信息1]] [AUTOINC [NEXTVALUE 增量开始值 [STEP步长值]]] [DEFAULT表达式1] [PRIMARY KEY | UNIQUE] [REFERENCES表名2 [TAG标识名1]] [,字段名2字段类型[(字段宽度[,小数位数])…]… 其他字段定义 [,PRIMARY KEY表达式2 TAG 标识名2 |,UNIQUE表达式3TAG标识名3] [,FOREIGN KEY表达式4TAG标识名4[NODUP] REFERENCES表名3[TAG标识名5]] [,CHECK逻辑表达式2[ERROR出错提示信息2]]);5.2 SQL定义功能 5.2.2 表的定义、修改、与删除;5.2 SQL定义功能 5.2.2 表的定义、修改、与删除;5.2 SQL定义功能 5.2.2 表的定义、修改、与删除;5.2 SQL定义功能 5.2.2 表的定义、修改、与删除;5.2 SQL定义功能 5.2.2 表的定义、修改、与删除;5.3 SQL的查询功能;5.3 SQL的查询功能;5.3 SQL的查询功能 5.3.1 SQL单表查询;在SELECT语句中,查询条件用WHER子句给出,条件表达式所用的运算符如下: ① 比较大小 =,,,=,=,!=或 ②确定范围 BETWEEN…AND 查询字段在指定范围 NOT BETWEEN…AND 查询字段不在指定范围 AND左端给出查寻范围下限,右端给出查寻范围上限;;⑤涉及空值的查询 查询某字段值为空的记录用IS NULL运算符 例6:查询“成绩”表中“成绩”为空值的学生信息 SELECT * FROM 成绩 WHERE 成绩 IS NULL ⑥复合条件查询 进行复合条件查询使用AND和OR 例7:查询来自“山东”省的男生姓名和专业编号;5.3 SQL的查询功能 5.3.1 SQL单表查询;数据的来源是多个表。与单表查询相比,有如下不同: 1、在FROM子句中,必须写上查询所涉及到的所有表名。 2、必须有连接条件。一般是两个表中相同或相关的字段。 3、条件中使用的字段重名时应加上表名作为标识。 4、输出时字段重名时应作区分。 多表查询的核心语句格式是: SELECT输出列1,…,输出列n FROM 表l JOIN 表2ON 连接条件1 [JOIN表3 ON 连接条件2…] ;5.3 SQL的查询功能 5.3.2 SQL多表查询;5.3 SQL的查询功能 5.3.2 SQL多表查询;5.3 SQL的查询功能 5.3.2 SQL多表查询; ;例3:显示选修了“英语”的学生姓名、专业名称和他们的成绩。 首先通过课程表确定“英语”的课程编号,然后与成绩表连接,找到选修该课程的学号,再到学生表中找到学生姓名,以及专业编号,再与专业表连接找到对应的专业名。因此,课程、成绩、学生、专业这四个表要同时使用,通过并列的连接条件完成连接。 SELECT 课程名,姓名,专业名称,成绩 ; FROM 课程 JOIN 成绩 ON 课程.课程编号 = 成绩.课程编号 ; JOIN 学生 ON学生.学号 =成绩.学号 ; JOIN 专业 ON专业.专业编号 =学生.专业编号 ; WHERE 课程名 = 大学英语;5.3 SQL的查询功能 5.3.2 SQL多表查询 ;5.3 SQL的查询功能 5.3.3 SQL嵌套子查询;5.3 SQL的查询功能 5.3.3 SQL嵌套子查询;5.3 SQL的查询功能 5.3.3 SQL嵌套子查询;5.3 SQL的查询功能 5.3.3 SQL嵌套子查询;5.3 SQL的查询功能 5.3.3 SQL嵌套子查询;5.3 SQL的查询功能 5.3.4 SQL分组统计查询;注意:WHERE短语与HAVING短语的区别 WHERE短语用于表的筛选条件; HAVING短语用于对分组结果的筛选条件。 分组查询通常包含计算。分组查询常用的计算函数(P122):求平均值AVG(字段名)、计数COUNT(*)、求最大值MAX(字段名)、求最小值MIN(字段名)、求和SUM(字段名);5.3 SQL的查询功能 5.3.4 SQL分组统计查询;5.3 SQL的查询功能 5.3.4 SQL分组统计查询
显示全部
相似文档