文档详情

本章要求1、掌握sql的数据定义,创建、删除和修改基本表.ppt

发布:2018-05-27约2.13万字共106页下载文档
文本预览下载声明
第3章 关系数据库标准语言SQL 本章要求 1、掌握SQL的数据定义,创建、删除和修改基本表;了解基本数据类型; 2、掌握SQL的查询语句,单表查询(列、元组、排序、集函数(AVG,SUM,COUNT,MAX,MIN),分组,连接查询(等值和非等值连接,自身连接,外连接,复合条件连接),嵌套查询(IN,比较、ANY,ALL,EXISTS); 3、掌握SQL的更新语句,INSERT,UPDATE,DELETE 4、了解SQL的视图(什么是视图) 3.1 SQL概述 SQL语言的发展及标准化 SQL语言是当前最为成功、应用最为广泛的关系数据库语言,今天广泛应用于各种大型数据库,如SYBASE、INFORMIX、 ORACLE、DB2、INGRES、SQL SERVER 2000等,也用于各种小型数据库,如FOXPRO、ACCESS。 随着关系数据库系统和SQL语言应用的日益广泛,SQL语言已制订了多个SQL标准。 3.1.1 SQL语言的主要特点 综合统一,集数据定义DDL、操纵DML、控制DCL于一体 高度非过程化,即用户只要提出“干什么”即可,不必管具体操作过程,也不必了解数据的存取路径,只要指明所需的数据即可。 面向集合的操纵方式,每个命令的操作对象是一个或多个关系(元组集合),结果也是一个关系。 SQL语言既是自含式语言,又是嵌入式语言。可独立使用,也可嵌入到宿主语言中。语法结构相同。 自含式语言可以独立使用交互命令,适用于终端用户、应用程序员和DBA; 嵌入式语言使其嵌入在高级语言中使用,供应用程序员开发应用程序。 5.类似于英语,简洁易用。 表3.1 3.1.2 SQL语言的基本概念 首先介绍两个基本概念:基本表和视图。 基本表(BASE TABLE):是独立存在的表,不是由其它的表导出的表。一个关系对应一个基本表,一个或多个基本表对应一个存储文件。 视图(VIEW):是一个虚表,是从一个或几个基本表导出的表。它本身不独立存在于数据库中,数据库中只存放视图的定义而不存放视图对应的数据,这些数据仍存放在导出视图的基本表中。当基本表中的数据发生变化时,从视图中查询出来的数据也随之改变。 例如:学生数据库中有学生基本情况表STUDENT(SNO,SNAME,SSEX,SAGE,SDEPT),此表为基本表,对应一个存储文件。可以在其基础上定义一个男生基本情况表STUDENT_MALE(SNO,SNAME,SAGE,SDEPT) 它是从STUDENT中选择SSEX=’男’的各个行,然后在SNO,SNAME,SAGE,SDEPT上投影得到的。 在数据库中只存有STUDENT_MALE的定义,而STUDENT_MALE的记录不重复存储。 在用户看来,视图是通过不同路径去看一个实际表,就象一个窗口一样,我们通过窗户去看外面的高楼,可以看到高楼的不同部分,而透过视图可以看到数据库中自己感兴趣的内容。 3.2 数据定义 SQL语言使用数据定义语言(DATA DEFINITION LANGUAGE,简称DDL)实现其数据定义功能,可对基本表、视图、索引进行定义和撤消。 表3-2 CREATE DROP ALTER 表 √ √ √ 视图 √ √ 索引 √ √ 3.2.1 创建、修改和删除基本表 1 定义基本表 基本表是关系数据库的基本组成单位,它物理地存储于数据库的存储文件中。 1. 定义一个基本表时主要包括以下几个组成部分: (1)字段名(列名):字段名可长达128个字符。字段名可包含中文、英文字母、下划线、#号、货币符号(¥)及AT符号(@)。同一表中不允许有重名列; (2)字段数据类型; (3)字段的长度、精度和小数位数; (4)NULL值与DEFAULT值 SQL语法格式 基本语法格式为: CREATE TABLE 表名(列定义[{,列定义|表约束}]) 表名是合法标识符,最多可有128个字符,如S,SC,C,不允许重名。 列定义:列名数据类型[DEFAULT] [{列约束}] DEFAULT:若是某字段设置有默认值,当该字段未被输入数据时,则以该默认值自动填入该字段。 例 建立一个S表,对SNO字段进行NOT NULL约束。 CREATE TABLE S (SNO CHAR(10) NOT NULL UNIQUE, SN CHAR(20), AGE INT, SEX CHAR(2) DEFAULT ’男’ , DEPT CHAR(20)); 当SNO为空时,系统给出错误信息,无NOT NULL约束时,系统缺省为NULL。 UNIQUE 取值唯一 2 修改基本表 由于应用环境和应用需求的变化,经常需要修改基
显示全部
相似文档