文档详情

数据库系统和应用04.ppt

发布:2017-04-26约2.13万字共178页下载文档
文本预览下载声明
结构化查询语言SQL (Structured Query Language) 是一种介于关系代数与关系演算之间的语言,其功能包括查询、操纵、定义和控制四个方面,是一个通用的、功能极强的关系数据库语言,目前已成为关系数据库的标准语言。;SQL的历史 SQL语言最初是由IBM公司1974年在原型的关系数据库管理系统SYSTEM R上开发的语言。 1979年,ORACLE公司首家推出商业上可执行的SQL。 如今,SQL成为国际上标准的数据库存取语言。;SQL的标准 美国国家标准学会(ANSI )将SQL作为关系数据库管理系统的标准语言,并且定义在ANSI x3.125---1989”具有完整性增强特征的数据库语言SQL”文档中,即ANSI SQL89。 1986.10 ISO SQL86 1987.6-1989.4 ISO SQL89 1992年 ISO SQL92 SQL2 2000年 ISO SQL99 SQL3 2003年 SQL2003,包含了XML相关内容 2006年 SQL2003,定义了SQL与XML(包含XQuery)的 关联应用 ;4.1 SQL概述及其特点 1. SQL概述 按其功能分为四大类;SQL 的特点; 2. SQL数据库的体系结构 按支持SQL的数据库管理系统可称其SQL数据库,其结构基本上采用三级结构,但所用术语与传统关系模型的术语有些不同。;用户1; 说明: 一个SQL数据库是表的汇集,它用一个或若干个SQL模式定义; 基本表都是一个实际存在的关系,由行集构成,一行是列的序列,每列对应一个数据项; 一个表或者是一个基本表,或者是一个视图; 每个存储文件与外部存储上一个物理文件对应; 用户可以用SQL语句对视图和基本表进行查询操作; SQL用户可以应用程序,也可以是终端用户。; 格式: SELECT [ALL|DISTINCT]目标列表达式[,目标列表达式,···] FROM 基本表名或视图名[,基本表名或视图名,···] [WHERE 条件表达式] [GROUP BY 列名1[HAVING条件表达式]] [ORDER BY 列名2[ASC|DESC]]; 描述: 根据WHERE子句的条件表达式,从FROM子句指定的基本表或视图中找出满足条件的元组,再按SELECT子句中的目标列表达式,选出元组中的属性值形成结果表。如果有GROUP BY子句则将结果按列名1的值进行分组,该属性??相等的元组为一个组。通常会在每组中作用集函数。如果GROUP子句带有HAVING短语,则只有满足指定条件的组才予输出。如果有ORDER BY子句,则结果表还要按列名2的值升序或降序排列。;1. 选择表中的若干列 选择表中的指定列; 选择表中的所有列; 结果列的显示顺序; 使用列表达式; SELECT中的目标列表达式可以是表中的列,也可以是表达式,包括算术表达式、字符串常数、函数等。(字符串用单引号定界)。 使用的列的别名: 列名 [AS] 列的别名;例1:求全体学生的学号、姓名。 例2:求全体学生的详细信息。 例3:求学生学号和学生出生的年份 (经过计算的值)。 例4:求学生的学号和出生年份,显示时 使用别名 Student_No 和 Birth_Day。 ;2. 选择表中的若干元组 ① 消除取值重复行 查找相异的行:在SELECT语句中使用关键字 DISTINCT 原本不完全相同的元组,经过向某些列投影操作后,可能变成相同的行了。如果想去掉结果表中的重复行,必须指定 DISTINCT 短语,没有指定,则使用用缺省值 ALL,意为保留结果表中所有的行。 例5:求选修了课程的学生学号。;② 查询满足条件的元组 可以通过WHERE子句来实现。WHERE常用的查询条件如下表所示。; 大小比较 条件表达式的形式如下: 属性列 比较运算符 {列名|常量|表达式} 其中:字符串常量和日期常量要用一对 单引号括起来。 例6:求年龄大于等于20岁的学生姓名和年龄。; BETWEEN 确定范围 谓词BETWEEN AND与NOT BETWEEN AND 的一般格式为: 属性列[NOT] BETWEEN a AND b 查询属性值在(或不在)指定范围内的元组 其中:a 为
显示全部
相似文档