登陆注册
14082400000006

第6章 Oracle数据库基础——SQL语言(1)

5.1 SQL概述

关系数据库语言SQL对关系模型的发展和商用RDBMS的研制起着很重要的作用,是关系数据库的标准语言,广泛应用于商用系统中。

SQL不仅具有丰富的查询功能,而且具有数据定义和数据控制功能,是集DDL、DML、DCL为一体的标准的关系数据库语言。不同的数据库厂家在自己的数据库产品(包括Oracle)中都实现了标准SQL语句的功能,并且都在标准SQL的基础上进行了扩充。

本章较详细地介绍在Oracle中如何使用数据定义语言DDL实现表、视图、索引三类对象的创建、修改、删除,以及在建立表结构后如何使用数据操作语言DML对表进行查询、插入、更新、删除数据等操作,同时介绍在查询、插入、更新、删除操作时如何使用各种SQL函数。最后介绍如何使用数据控制语言DCL实现权限的授予和回收,以及如何将SQL语句嵌入到宿主语言中使用等内容。

5.1.1 SQL发展历程

SQL语言虽然名为查询语言,但实际上具有定义、查询、更新和控制等多种功能。按照ANSI(美国国家标准协会)的规定,SQL被作为关系型数据库管理系统的标准语言。目前,绝大多数流行的关系型数据库管理系统,如Oracle,Sybase,Microsoft SQL Server,Access等都采用了SQL语言标准。虽然很多数据库都对SQL语句进行了再开发和扩展,但是包括SELECT,INSERT,UPDATE,DELETE,CREATE和DROP在内的标准的SQL命令仍然可以用来完成几乎所有的数据库操作。

最早的SQL标准是于1986年10月由ANSI公布的,随后,ISO采纳它为国际标准,1989年4月,ISO提出具有完整性特征的SQL,称为SQL-89。在SQL-89的基础上经过三年的研究和修改,ISO于1992年11月公布了SQL新标准,即SQL-92。SQL标准化工作还在继续,新的标准被命名为SQL3。

5.1.2 SQL特点

(1)SQL是一种一体化的语言

SQL语言集数据定义、数据操纵、数据查询、数据控制功能于一体,可以完成数据库生命周期中的全部工作。

(2)SQL语言是一种高度非过程化的语言

SQL语言是非过程化的语言,它没有必要告诉计算机“如何”去做,而只需要描述用户要“做什么”,SQL语言就可以将要求交给系统,自动完成全部工作。这不但减轻用户的负担,而且提高数据的独立性。

(3)SQL语言非常简洁

虽然SQL语言功能很强,但只有为数不多的几条命令,给出了分类的命令动词。另外SQL的语法非常简单,很接近自然语言,因此容易学习和掌握。

(4)同一种语法结构提供两种使用方式

SQL语言可以直接以命令方式交互使用,也可以嵌入到程序设计语言(如:C,COBOL,FORTRAN等)中以程序方式使用。现在很多数据库应用开发工具,都将SQL语言直接融入到自身的语言中,使用起来更方便。此外,尽管SQL的使用方式不同,但SQL语言的语法基本上是一致的。

(5)面向集合的操作方式

非关系数据模型采用面向记录的操作方式,操作对象是一条记录。而SQL语言采用集合操作方式,不仅操作对象、操作结果都可以是元组的集合(关系),而且一次插入、更新、删除的对象也可以是元组的集合(关系)。

5.2 SQL的数据定义

SQL的数据定义功能包括数据库、基本表、视图、存储过程和索引的建立、修改、删除。但SQL不提倡修改视图和索引的定义,如果想修改视图和索引的定义,只能先将它们删除,然后再重建。有些实际的关系数据库产品(如Oracle)允许修改视图的定义。

5.2.1 基本表的建立、修改、删除

表是关系数据库中最重要的数据库对象,其他的数据库对象的创建及各种操作都是围绕表进行的,可以将表看作含列和行的表单。表是数据库中存储数据的结构。

5.2.1.1 示例数据库表结构

后面的例子中要用到“学生——课程”数据库中的表,在此先介绍“学生——课程”数据库中“学生”表、“课程”表和“学生选课”表这三个表的结构。

“学生”表student由学号(sno)、姓名(sname)、性别(ssex)、年龄(sage)、所在系(sdept)五个属性组成,可记为:student(sno,sname,ssex,sage,sdept),其中主键为sno。

“课程”表course由课程号(cno)、课程名(cname)、教师名tname(cpno)、学分(ccredit)四个属性组成,可记为:course(cno,cname,tname,ccredit),其中主键为cno。

“学生选课”表sc由学号(sno)、课程号(cno)、成绩(grade)三个属性组成,可记为:sc(sno,cno,grade),其中主键为(sno,cno),sno 和cno是该表的外键,分别参考student和course表的sno和cno列。

另外,介绍部门和雇员数据库中用到的“部门”信息表,“雇员”信息表和“工资等级”表的结构。

“部门”信息表dept由部门号(deptno)、部门名称(dname)、部门地点(loc)3个属性组成,可记为:DEPT(deptno,dname,loc),其中主键为deptno。

“雇员”信息表emp由雇员编号(empno)、雇员姓名(ename)、工作(job)、经理编号(mgr)、工资(sal)、部门号(deptno)6个属性组成,可记为:emp(empno,ename,job,mgr,sal,deptno),其中主键为empno。deptno是该表的外键,参考DEPT表的deptno列。

“工资等级”表SALGRADE由等级号(grade)、最低工资(lowsal)、最高工资(highsal)3个属性组成,可记为SALGRADE(grade,lowsal,highsal),其中主键为grade。

5.2.1.2 创建基本表

1.创建基本表的语法

一个用户中表名要唯一,一个表中列名要唯一。

数据类型是Oracle所提供的基本数据类型。

建表的同时可以定义与该表有关的完整性约束条件保证数据的正确和有效,这些完整性约束条件被存入到系统的数据字典中。如果约束条件涉及表中的多列时,必须定义在表级,否则既可以定义在表级,也可以定义在列级。

通过使用DEFAULT 选项可以给列设定一个默认值。此选项可以避免在插入数据时没有指定列的值时往该列中插入NULL值。默认值可以是一个常量、表达式、SQL函数,比如:SYSDATE、USER等,默认值必须与列的数据类型匹配。例如:

SQL>CREATE TABLE AUDIT1(USERNAME VARCHAR2(12)DEFAULT USER,

TIMES DATE DEFAULT SYSDATE);

表名和列名取名时第一个字符必须是A~Z或a~z(存储时全为大写),第一个字母之后的字符可以任意,包括数字或$、#和(不能是逗号)。取名最长不得超过30个字符。

2.Oracle提供的基本数据类型

当建立一张表时,必须指定表中所有列的数据类型。Oracle有许多数据类型可以满足用户的需求。数据类型总的可以划分成字符型、数字型、日期型、LOB类型等。

(1)字符类型

字符数据类型用于存储字符数据。当定义字符数据时,必须指定列的长度。有下列两种字符数据类型。

CHAR(<SIZE>):存储固定长度的字符串,最大长度由SIZE确定。CHAR列中存储的数据如果不到SIZE的长度,补充空格达到SIZE的长度。SIZE的值从1到2000。

VARCHAR2(<SIZE>):是一个可变长度的字符串,最大长度由SIZE确定,最多可存储4000字节。VARCHAR2变量存储多少数据,就只需要多少空间。

(2)数字类型

数字类型用于存储正负整数、浮点数,值的范围从-1×10-130到9.999……99×10125,精度可达38位。超出范围将引起错误。有一种数字类型NUMBER[<P>,<S>],可以存储总的长度是P位,小数点后是S位。不一定非要定义总长度与小数点后的长度。

(3)日期类型

日期类型DATE用于存储日期和时间信息。每一个日期类型中包含下列信息:世纪(CENTURY)、年(YEAR)、月(MONTH)、日(DAY)、小时(HOUR)、分(MINUTE)、秒(SECOND)。

SYSDATE系统函数返回的是正在联结的数据库服务器的系统日期和时间。如果在日期中没有指定时间TIME,默认时间为半夜零点零分零秒(00:00:00)。

(4)LOB数据类型

LOB(Large Object,大对象)数据类型存储非结构化的数据,比如一个二进制文件、一幅图片或一个外部文件。有三种LOB类型,这些LOB类型的目的和存储位置是有区别的。

一个LOB列可以存储高达4 GB的数据,数据存储在数据库中。对LOB数据的操作需要使用DBMSLOB包。在表的LOB列中存储了LOB的定位符(LOCATOR)。

BFILE数据存储在服务器的操作系统文件中。BFILE列可以访问Oracle数据库外的二进制文件,表的BFILE类型的列中存储的是BFILE指针,用来指向服务器文件系统中的一个二进制文件。Oracle提供APIs对文件中的数据进行访问。用来对文件中的数据进行访问的主要接口是DBMSLOB包和OCI。

3.完整性约束

为了保证数据的完整性和一致性,以及多张表之间的参考完整性,在建表时或修改表时可以指定一些约束条件,限制表中列的取值。约束是一些规则,约束在数据库中不占存储空间。相反,约束只存储在数据字典中,并且只有生效的约束在SQL及PL/SQL的执行时才起作用。有时候,为了改善大批数据装入的操作性能,可以用ALTER TABLE语句使约束失效,失效的约束不起作用。

例5-2 将emp表的PK1主键约束失效。

ALTER TABLE emp DISABLE CONSTRAINT pk1

此时emp表的主键约束不起作用。

例5-3 将emp表的PK1主键约束生效。

ALTER TABLE emp ENABLE CONSTRAINT pk1

此时emp表的主键约束起作用。

表的完整性约束可定义为两级:表级约束和列级约束。

表级约束定义的完整性约束可以约束表中的任意一列或多列。可以定义除了NOT NULL以外的任何约束。如果要为表中多列的组合定义一个约束(例如,包含多列的主键),则必须通过表级约束来定义。语法如下:

column datatype,[CONSTRAINT constraint name]constraint type(column……)

列级约束只能约束其所在的某一列。可以定义任何约束。语法如下:

column datatype[CONSTRAINT constraint name]constraint type

从语法上可以看到,CONSTRAINT关键字和constraint name(约束名)是可选的。如果没有指定CONSTRAINT关键字和constraint name(约束名),Oracle将自动生成以SYS开头的唯一的约束名字。

Oracle提供了五种约束条件保证数据的完整性和参考完整性,包括:非空约束(NOT NULL)、唯一约束(UNIQUE)、主键约束(PRIMARY KEY)、检查约束(CHECK)和外键约束(FOREIGN KEY)。

(1)NOT NULL约束(非空约束)

用于指定某列不能为空。只能是列级约束,作用于单列。例如:

ename char(10)CONSTRAINT e2 NOT NULL

其中:CONSTRAINT是一个关键字,e2是约束名。说明ename列不能为空,必须输入数据。默认情况,Oracle允许任何列上有空值。

(2)UNIQUE约束(唯一约束)

用于将一列或多列的组合作为唯一键,确保被作用的列中没有两行包含重复值。可以是表级或列级约束。如果要为表中两列或多列定义一个唯一完整性约束,则必须通过表级约束来定义。唯一约束允许有NULL值。当建立唯一约束时Oracle系统自动建立一个B树的UNIQUE索引。

(3)CHECK约束(检查约束)

用来定义一个条件,使表中的每条记录必须符合该条件。CHECK约束可以参考同一行中其他的列,但不能参考其他行或其他表中的列。在定义CHECK条件时,可以调用如SYSDATE、USER等系统函数。CHECK约束不能作用于数据类型是LOB的列中。一个列上可以有多个CHECK约束条件。一个CHECK约束可以作用于一列或多列中。如果CHECK约束要作用于多列时,必须通过表级约束来定义。例如:

sal number(7,2)CONSTRAINT e3

check(sal between 1000 and 8000)/*列级约束*/

其中:CONSTRAINT是一个关键字,e3是约束名,check是关键字,sal between 1000 and 8000是一个布尔条件,用括号将条件括起来说明sal列的值必须在1000到8000范围内。

CONSTRAINT e3 CHECK(sal between 1000 and 8000

OR sex in(′m′,′f′))/*表级约束*/

说明sal列的值必须在1000到8000范围内,sex列的取值必须是“男”或“女”。

同类推荐
  • 音视频合成制作

    音视频合成制作

    本书共分4篇6章,其中第1篇简介音视频合成的编导基础,第2篇主要介绍Sony Cinescore 1电影音乐自动合成,第3篇主要介绍Vegas 7.0音视频剪辑合成,第4篇主要介绍Adobe Audition 2.0、Cakewalk SONAR 6和Steinberg Nuendo 3的音视频合成。本书可以作为音乐、美术、动画、舞蹈、影视、戏剧等艺术院校视听艺术合成制作课程的教材,也可以作为相关人员的自学用书。
  • 信息革命

    信息革命

    随着经济社会的快速发展,电子产品走进了千家万户,与电子产品相伴的信息技术也已渗透到人们生产生活的方方面面。加强信息技术普及,已成为业内人士的共识。鉴于此,在有关部门的大力支持下,经过认真筹划,我们编辑出版了《信息革命》一书。该书以时间为经,在记述信息技术发展历程的同时,深入浅出地介绍了信息技术的相关知识,对人们更好地利用现代信息技术服务经济社会建设和个人生产生活必将产生积极作用。本书由李大东主编。
  • 中国3D打印的未来

    中国3D打印的未来

    自2012年以来,有关3D打印的报道屡见报端,这一新型制造技术引起了全世界的广泛关注。《中国3D打印的未来》作者、中国3D打印技术产业联盟秘书长罗军认为,中国从20世纪90年代初开始涉足3D打印技术,并取得了巨大进展,但与国外同行相比仍存在一定差距。特别是中国3D打印企业普遍存在“小而散”、各自为政的现象,如何发挥整合优势、抱团发展是目前亟需解决的问题。如果能够加强同行合作,抱团发展,形成合力,相信3D打印会成为唯一一项中国有可能赶超世界先进水平的技术。
  • 数字博物馆研究与实践2009

    数字博物馆研究与实践2009

    本书汇集了“2009年北京数字博物馆研讨会”与会代表提交的60余篇论文和演讲报告、应用案例,分为数字博物馆(科技馆)发展研究探讨、数字博物馆(科技馆)多样性发展模式、数字技术在博物馆(科技馆)展陈中的应用、数字博物馆(科技馆)建设实践、数字博物馆(科技馆)实现技术和数字博物馆调研报告等六个部分。本书内容囊括了对数字博物馆(科技馆)建设宏观层面的全局思考以及微观层面的具体实践。在宏观层面,介绍了数字博物馆(科技馆)在国内外的发展现状与趋势,通过剖析典型案例,探讨数字博物馆(科技馆)建设的意义、目标、作用、建设原则、要素、特征及目前建设工作中存在的现实问题与对策。
  • 中国移动智能手机的秘密

    中国移动智能手机的秘密

    《中国移动智能手机的秘密》是一本关于移动终端和移动互联网的科普书。作者将这18年通信行业中的学习、思考、实践积累成《中国移动智能手机的秘密》与大家分享。书本系统总结了手机的发展历史、TD产业界“从2G向3G演进”的移动终端产业分化重组进程、智能手机的使用方法用方法和应用指南,以及对移动互联网发展独特思考。
热门推荐
  • 我的绝品女神

    我的绝品女神

    【都市新书发布】偶然得到九灵仙子元神传承,乡村小子沈修去都市找未婚妻,一路触敌逆鳞,桃花运纷至沓来应接不暇。什么!你们要献身报答我?我沈修可是正人君子啊,你这是在侮辱我人品!不过我脾气好,侮辱就侮辱吧,我现在预订开房啊,到底哪家酒店设施齐全呢……看乡村小子如何醉笑都市,玩转桃运!【百万字数人品保证,企鹅群:543050331,老司机赶紧上车!】
  • 终结刺客

    终结刺客

    十步杀人,千里不留行。重生三年前,有恩报恩,有仇报仇。杀人遇上不死人……不敢相信的事实!
  • 凤戏江山:妖娆兽妃戏邪王

    凤戏江山:妖娆兽妃戏邪王

    【宠文女强一对一】她,二十一世纪通缉榜前三的金牌杀手,令人闻风丧胆的代号“z”!一次意外穿越,成为北燕国的皇室公主。KAO!跟我玩什么浴火重生?当清冷的眼眸睁开,整个天下为之疯狂。他,是身份尊贵的天神之子,冷漠绝情的他,却单单对她情钟。那夜惊鸿一面,从此命运又该何去何从?“你仿佛是致命的毒药,让我一再沦陷……汝心之内,容吾永住。”
  • 附妖灵

    附妖灵

    万物皆有灵性,可成妖,妖有灵根,可为人之用,谓之附妖。
  • 都市神座

    都市神座

    叶知微推开了一扇门,加入了一个不科学的非唯物组织。从此成为了非正常人类中的一员,见识了许多奇怪的人或事。原来神话,不止是传说而已。不一样的都市,不一样的异能……PS:普通书友群:1780.708.42VIP书友群(粉丝值2000以上),进群请验证:9855.70.38PS2:诸位有没有好一点的书名推荐一下?好想改……
  • 相伴终是敌不过深情告白

    相伴终是敌不过深情告白

    一个青梅竹马甜宠小虐的故事,没有尽头的爱情。苏南城爱了许枝瑾一辈子,他不甘心,还想再爱一辈子。许枝瑾等了苏南城两个三年,可她不悔。
  • 谁来为教育买单

    谁来为教育买单

    在古代中国,千千万万的知识分子相信,这是改变自身和家族命运的不二法门。殿试试卷一页。在经历了1000多年的考试之后,中国人真的养成了“考试情结”? 改革开放之后恢复高考,现在的教育制度深受科举的影响,从而扼杀了教育的内在精神,教育的目的本来是培养健康的、全面发展的个体,但现在教育的精神都被异化,人人都变成考试人。我们似乎看到这样的身影,清朝状元翁同龢秉烛夜读,吴敬梓笔下的范进在嘶声呐喊……
  • 福妻驾到

    福妻驾到

    现代饭店彪悍老板娘魂穿古代。不分是非的极品婆婆?三年未归生死不明的丈夫?心狠手辣的阴毒亲戚?贪婪而好色的地主老财?吃上顿没下顿的贫困宭境?不怕不怕,神仙相助,一技在手,天下我有!且看现代张悦娘,如何身带福气玩转古代,开面馆、收小弟、左纳财富,右傍美男,共绘幸福生活大好蓝图!!!!快本新书《天媒地聘》已经上架开始销售,只要3.99元即可将整本书抱回家,你还等什么哪,赶紧点击下面的直通车,享受乐乐精心为您准备的美食盛宴吧!)
  • 重生之为你长大

    重生之为你长大

    人生若只如初见,何事秋风悲画扇……陈延武和张颖,坏大叔和小萝莉,一个有爱的故事,一个像画一样的故事。现在的努力,只是为了以后给她一个温馨美满的家,重生了,就要为你长大,做守护你的翅膀!
  • 无限之随机选择

    无限之随机选择

    从天而降的一个耳坠将某一个一年不出几次门,出门不走一百米的渣男砸的头破血流,晕头转向的。当某个渣男终于清醒了一点,起身骂道“靠,谁砸的,想死啊”然后将耳坠捡了起来又继续面孔朝天说道“那个不要脸的瞧不起哥,拿这么小的东西砸哥,我累死你也砸不死我”话音刚落又一个耳坠从天而降直接将某渣男砸死。渣男最后的想法是“我去,我说说而已。还非得用这小破玩意将我砸死啊……”