Oracle9i关系数据库实用教程(第二版) 蔡立军及教学大纲 03新.ppt
文本预览下载声明
本章内容 3.1 SQL简介 3.2 SQL基本语法 3.3 数据查询语言(DQL) 3.4 数据操纵语言(DML) 3.5 数据定义语言(DDL) 3.6 数据控制语言(DCL) 3.7 常用函数 一、CREATE语句 1.表的建立 表是存储用户数据的基本结构。 建立表主要指定义下列信息: 列定义 完整性约束 表所在表空间 存储特性 可选择的聚集 3.5 数据定义语言(DDL) (1)建立一个新表的语句格式 可以利用CREATE TABLE语句,来建立一个全新的表,但前提是:数据库必须已经存在。语句格式为: CREATE TABLE table(field1 type[(size)][index1],field2 type[(size)][index2],...,nultifieldindex[,...]) (2)注意事项 ①创建表时要把较小的不为空的字段放在前面,可能为空的字段放在后面。 ②创建表时可以用中文的字段名,但最好还是用英文的字段名。 ③创建表时可以给字段加上默认值,例如DEFAULT SYSDATE。这样每次插入和修改时,不用程序操作这个字段都能得到动作的时间。 ④创建表时可以给字段加上约束条件。例如不允许重复UNIQUE,关键字PRIMARY KEY。 2.表索引的建立 索引是一种数据库对象。对于在表或聚集的索引列上的每一值将包含一项,为行提供直接的快速存取。在下列情况下,Oracle可利用索引改进性能: ?按指定的索引列的值查找行。 ?按索引列的顺序存取表。 表索引的建立主要采用的是CREATE INDEX语句。这个命令是对一个已存在的表建立索引,语句格式为: CREATE[UNIQUE]INDEX index ON table(field1[ASC|DESC], field2[ASC|DESC],...) [WITH {PRIMARY|DISALLOWNULL|IGNORENULL}] CONSTRAINT条件子句的功能也是类似索引(INDEX)的,虽然CONSTRAINT 也可以建立表之间的关联性。如: (1)单一字段索引语句格式: CONSTRAINT name{PRIMARY KEY|UNIQUE|REFERENCES foreigntable[(foreignfield1,foreignfield2)]} (2)多字段索引语句格式: CONSTRAINT name {PRIMARY KEY(primary1[,primary2[,...]]) |UNIQUE(unique1[,unique2[,...]]) |FOREIGN KEY (ref1[,ref2[,...]]) |REFERENCES foreigntable[(foreignfield1[, foreignfield2[,...]])]} 3.视图的建立 视图是一个逻辑表,它允许操作者从其它表或视图存取数据,视图本身不包含数据。视图所基于的表称为基表。 引入视图有下列作用: ?提供附加的表安全级,限制存取基表的行或/和列集合。 ?隐藏数据复杂性。 ?为数据提供另一种观点。 ?促使Oracle的某些操作在包含视图的数据库上执行,而不在另一个数据库上执行。 建立视图的语句格式为: CREATE VIEW view AS SELECT table1.field1,…,table2.field1… FROM table1,table2….; 4.同义词的建立 同义词为表、视图、序列、存储函数、包、快照或其它同义词的另一个名字。使用同义词为了安全和方便。对某一对象建立同义词可有下列好处: ?引用对象不需指出对象的持有者。 ?引用对象不需指出它所位于的数据库。 ?为对象提供另一个名字。 建立同义词使用的语句格式为: CREATE SYNONYM symnon_name FOR [username.]tablename; 5.用户的建立 建立用户使用的语句格式为: CREATE USER username IDENTIFIED BY password; 二、ALTER语句 1 .ALTER语句格式 用ALTER语句,可以修改表、索引,或对视图的字段重新设计。语句格式为: ALTER TABLE table {ADD {COLUMN field type[(size)][CONSTRAINT index] |CONSTRAINT multifiedindex} |DROP {COLUMN fiel
显示全部