在 Oracle 之中数据表就被称为
数据库对象,而对象的操作语法一共有三种:
· 创建对象:CREATE 对象类型 对象名称 [选项];
· 删除对象:DROP 对象类型 对象名称 [选项];
· 修改对象:ALTER 对象类型 对象名称 [选项]。

创建表

CREATE TABLE 表名称 (
字段 类型 [DEFAULT 默认值] ,
字段 类型 [DEFAULT 默认值] ,
...
字段 类型 [DEFAULT 默认值]
)

一般而言,默认值是为了防止用户在增加数据时为 null 的问题。

复制表

实际上所谓的复制表严格来讲不是复制的含义,是针对于一个子查询(返回多行多列)的结果进行表的创建,完整
语法如下:
CREATE TABLE 表名称 AS 子查询

注意点:关于事务与 DDL 的问题
· 事务可以控制的只是数据的更新操作(增加、修改、删除),而 DDL 是不受事务控制的;
· 在 Oracle 之中,如果发生了 DDL 操作,那么所有未提交的事务将会自动进行提交。

在 Oracle 之中有三类数据字典:
· user_*:用户可以使用的数据字典;
· dba_*:管理员可以使用到的数据字典;
· all_*:包含了当前用户可以访问的全部数据字典信息(有可能某些数据字典不属于此用户)。

为表重命名

RENAME 旧的表名称 TO 新的表名称 ;

截断表

TRUNCATE TABLE 表名称 ;

表一旦被截断,其所有占用的资源都将被彻底释放。

删除数据表

DROP TABLE 表名称 ;

闪回操作

从 Oracle 10g 起为了方便用户进行数据表的恢复。为 Oracle 增加了一个类似于 windows 的回收站功能,等于是所有
删除是数据表,首先保存在回收站之中,如果用户有需要也可以进行恢复。

范例:通过回收站恢复 emp10 数据表
FLASHBACK TABLE emp10 TO BEFORE DROP ;
范例:彻底删除数据表,不让删除的数据表经过回收站,在删除语句之后增加一个 PURGE
DROP TABLE emp10 PURGE ;
范例:删除回收站之中的一个表
PURGE TABLE empnull ;
范例:清空回收站
PURGE RECYCLEBIN ;
只有 oracle 有此特性

修改表结构

1、 为表中增加数据列
ALTER TABLE 表名称 ADD(
列名称 数据类型 [DEFAULT 默认值],
列名称 数据类型 [DEFAULT 默认值], ...)
2、 修改列结构
ALTER TABLE 表名称 MODIFY(
列名称 数据类型 [DEFAULT 默认值],
列名称 数据类型 [DEFAULT 默认值], ...) ;

从标准的 SQL 来讲,是一定要提供有数据表的修改操作的,但是从实际的开发来讲,任何人都不允许有随意修改数
据表结构的想法,而且更不能说自己去修改。

约束是保证表中数据完整性的一种有效检测手

非空约束(NOT NULL,NK)

DROP TABLE member ;
CREATE TABLE member(
mid NUMBER ,
name VARCHAR2(20) NOT NULL
) ;
INSERT INTO member(mid,name) VALUES(1,null)

此时,数据库会提示如下错误信息:“ORA-01400: 无法将 NULL 插入 ("SCOTT"."MEMBER"."NAME")”。此时会
明确的显示出那个字段上违反了非空约束。

唯一约束(UNIQUE,UK)

DROP TABLE member ;
CREATE TABLE member(
mid NUMBER ,
name VARCHAR2(20) NOT NULL ,
email VARCHAR2(20) UNIQUE
) ;
范例:增加正确的数据
INSERT INTO member(mid,name) VALUES (1,'王小强') ;
INSERT INTO member(mid,name,email) VALUES (1,'王大强','110@china.com') ;
在使用唯一约束的时候一定要记住,null 不属于重复的统计范畴。
范例:增加错误的数据
INSERT INTO member(mid,name,email) VALUES (1,'王中强','110@china.com') ;
此时出现了错误的提示信息:“ORA-00001: 违反唯一约束条件 (SCOTT.SYS_C0011101)”。但是与之前的非空约束相
比,此时的提示信息非常不明确。
DROP TABLE member PURGE ;
CREATE TABLE member(
mid NUMBER ,
name VARCHAR2(20)NOT NULL ,
email VARCHAR2(20) ,
CONSTRAINT uk_email UNIQUE(email)
) ;

此时,如果保存的数据出现了错误,则提示信息“ORA-00001: 违反唯一约束条件 (SCOTT.UK_EMAIL)”。
除了非空约束之外,所有的约束都一定要按照以上的方式进行设置,因为只有一个正常的名称才方便系统进行约束
的维护

主键约束(PRIMARY KEY,PK)

主键约束 = 非空约束 + 唯一约束。

DROP TABLE member PURGE ;
CREATE TABLE member(
mid NUMBER ,
name VARCHAR2(20)NOT NULL ,
CONSTRAINT pk_mid PRIMARY KEY(mid)
) ;
观察复合主键
DROP TABLE member PURGE ;
CREATE TABLE member(
mid NUMBER ,
name VARCHAR2(20) ,
CONSTRAINT pk_mid_name PRIMARY KEY(mid,name)
) ;
INSERT INTO member(mid,name) VALUES(1,'学冰') ;
INSERT INTO member(mid,name) VALUES(1,'学刁') ;
INSERT INTO member(mid,name) VALUES(2,'学刁') ;
正常人都不用,知道就行了,千万别用。

检查约束(CHECK,CK)

DROP TABLE member PURGE ;
CREATE TABLE member(
mid NUMBER ,
name VARCHAR2(20)NOT NULL ,
sex VARCHAR2(10) ,
age NUMBER(3) ,
CONSTRAINT pk_mid PRIMARY KEY(mid) ,
CONSTRAINT ck_sex CHECK (sex IN ('男','女')) ,
CONSTRAINT ck_age CHECK (age BETWEEN 0 AND 250)
) ;

即使设置了多个检查约束,那么也是一个一个约束进行过滤的。
但是在这里有一个提示:一般而言,你所设置的约束越多,在进行数据更新操作的时候性能就越低。所以很多时候
一些数据的检查操作都会交给程序完成

 主-外键约束(FOREIGN KEY,FK)

DROP TABLE member PURGE ;
DROP TABLE book PURGE ;
CREATE TABLE member(
mid NUMBER ,
name VARCHAR2(20)NOT NULL ,
CONSTRAINT pk_mid PRIMARY KEY(mid)
) ;
CREATE TABLE book(
bid NUMBER ,
title VARCHAR2(20) ,
mid NUMBER ,
CONSTRAINT pk_bid PRIMARY KEY(bid) ,
CONSTRAINT fk_mid FOREIGN KEY(mid) REFERENCES member(mid)
) ;

限制一:在删除主表之前,请一定要保证先删除子表。所以在删除数据表的时候应该先删除子表后再删除父表。

范例:强制删除
DROP TABLE member CASCADE CONSTRAINT ;
但是必须注意的是,强制删除是无法彻底删除的,所删除的数据表会保存在回收站之中。但是不建议使用强制删除
表的操作,还是建议按照先删除子表再删除父表的方式进行。

限制二:作为外键的字段在主表之中必须具备主键约束或者是唯一约束。

限制三:数据的级联操作问题

· 为了方便数据的删除,提供有一个级联删除操作,在主表数据删除的时候对应的子表数据会同时删除掉,在建立
外键的时候使用 ON DELETE CASCADE 来设置。

范例:设置级联删除
DROP TABLE book PURGE ;
DROP TABLE member PURGE ;
CREATE TABLE member(
mid NUMBER ,
name VARCHAR2(20)NOT NULL ,
CONSTRAINT pk_mid PRIMARY KEY(mid)
) ;
CREATE TABLE book(
bid NUMBER ,
title VARCHAR2(20) ,
mid NUMBER ,
CONSTRAINT pk_bid PRIMARY KEY(bid) ,
CONSTRAINT fk_mid FOREIGN KEY(mid) REFERENCES member(mid) ON DELETE CASCADE
) ;

· 如果在删除主表数据的时候不希望子表数据被一起删除掉,则可以使用级联更新操作,使用 ON DELETE SET
NULL 来设置。

范例:设置级联更新
DROP TABLE book PURGE ;
DROP TABLE member PURGE ;
CREATE TABLE member(
mid NUMBER ,
name VARCHAR2(20)NOT NULL ,
CONSTRAINT pk_mid PRIMARY KEY(mid)
) ;
CREATE TABLE book(
bid NUMBER ,
title VARCHAR2(20) ,
mid NUMBER ,
CONSTRAINT pk_bid PRIMARY KEY(bid) ,
CONSTRAINT fk_mid FOREIGN KEY(mid) REFERENCES member(mid) ON DELETE SET NULL
) ;

修改约束

首先明确:所有的约束一定要在表建立的同时就已经设置完成,不可能说表先去使用之后再回头设置约束,所以以
下的这些

1、 为表中增加约束
ALTER TABLE 表名称 ADD CONSTRAINT 约束名称 约束类型(约束字段) [选项] ;
但是需要提醒的是,此类的语法适合于唯一、主键、检查、外键约束的添加,而无法添加非空约束
2、 删除约束
ALTER TABLE 表名称 DROP CONSTRAINT 约束名称 ;

意义

oracle 表的创建与管理 约束的更多相关文章

  1. oracle表空间创建及管理

    一.数据文件和数据库逻辑存储结构: 一个表空间包含一个或多个数据文件,一个表空间包含一个或多个段,一个段包含一个或多个区,一个区包含一个或多个连续的数据库块,一个数据库块包含一个或多个操作系统块.段是 ...

  2. 【Oracle 】tablespace 表空间创建和管理

    1.表空间的概述 1. 表空间是数据库的逻辑组成部分. 2. 从物理上讲,数据库数据存放在数据文件中: 3. 从逻辑上讲,数据库是存放在表空间中,表空间由一个或者多个数据文件组成. 2.oracle的 ...

  3. Oracle表名、列名、约束名的长度限制

    Oracle数据库版本11.2.0.1.0 Oracle表名.列名.约束名的长度限制 1.查询用户所有的表 select * from USER_TABLES; 2.查询用户所有表的列 select ...

  4. SQL-46 在audit表上创建外键约束,其emp_no对应employees_test表的主键id。

    题目描述 在audit表上创建外键约束,其emp_no对应employees_test表的主键id.CREATE TABLE employees_test(ID INT PRIMARY KEY NOT ...

  5. Oracle数据库——表的创建与管理

    一.涉及内容 1.掌握使用OEM工具创建.修改和删除表. 2.掌握使用SQL语句创建.修改和删除表. 3.掌握使用SQL语句插入.修改和删除数据. 4.理解各种约束的作用,并能够使用OEM工具和SQL ...

  6. Oracle笔记(九) 表的创建及管理

    对于数据库而言实际上每一张表都表示的是一个数据库的对象,而数据库对象指的就是DDL定义的所有操作,例如:表.视图.索引.序列.约束等等,都属于对象的操作,所以表的建立就是对象的建立,而对象的操作主要分 ...

  7. Oracle系列十 创建和管理表

    常见的数据库对象 Oracle 数据库中的表 用户定义的表: 用户自己创建并维护的一组表 包含了用户所需的信息 如:SELECT * FROM user_tables;查看用户创建的表 数据字典: 由 ...

  8. SQL笔记-第二章,数据表的创建和管理

    数据类型 分5类:整数.数值.字符相关.日期时间以及二进制 1.整数 数据库系统 类型 说明 MYSQL tinyint [unsigned] 一个很小的整数.有符号的范围是-128 到127,无符号 ...

  9. SQL Fundamentals: 表的创建和管理(表的基本操作,闪回技术flashback,表结构修改)

    SQL Fundamentals || Oracle SQL语言 1.表的基本操作 (CREATE TABLE, DROP TABLE,TRUNCATE TABLE, RENAME tablename ...

随机推荐

  1. RSA与ECC的比较

    第六届国际密码学会议对应用于公钥密码系统的加密算法推荐了两种:基于大整数因子分解问题(IFP)的RSA算法和基于椭圆曲线上离散对数计算问题(ECDLP)的ECC算法.RSA算法的特点之一是数学原理简单 ...

  2. python 字符串格式化符号含义及注释

    字符串格式化符号含义 符号 说明 %C 格式化字符及其ASCII码 %S 格式化字符串 %d 格式化整数 %o 格式化无符号八进制数 %x 格式化无符号十六进制数 %X 格式化无符号十六进制数(大写) ...

  3. idea插件Lombok

    在spring boot 中,我们可以使用@Data标签,这样就不需要手动添加getter/setter方法了,但Idea会报错. 此时,我们需要安装Lombok插件,安装好插件后便可以解决这个问题. ...

  4. Redis redis-trib集群配置

    redis文档:http://doc.redisfans.com/ 参考:https://www.cnblogs.com/wuxl360/p/5920330.html http://www.cnblo ...

  5. 探索ORM之iBati(一)

    ibatis   iBATIS一词来源于“internet”和“abatis”的组合,是一个由Clinton Begin在2001年发起的开放源代码项目.最初侧重于密码软件的开发,现在是一个基于Jav ...

  6. Oracle EBS 应收发票取值

    SELECT ct.trx_number ,ctl.description ,fnd_flex_ext.get_segs('SQLGL' ,'GL#' ,gcc.chart_of_accounts_i ...

  7. 使用Membership,您的登录尝试不成功。请重试"的解决方法

    提示信息是标准Login控件产生的,打开数据库,检查aspnet_Membership表,检查IsLockedOut字段的值是否为False, 如果为True,表示这个用户锁定了,把它改成False即 ...

  8. Flask 参数简介

    我们都知道学习了Flask的时候它里面的参数是有很多种的参数  都是需要相互进行调用传递的  今天就简要分析一些常见的参数 首先导入Flask之后看 源码 from flask import Flas ...

  9. [控件] BookTextView

    BookTextView 效果 说明 1. 支持富文本 2. 支持自定义view 3. 支持阅读百分比 源码 https://github.com/YouXianMing/UI-Component-C ...

  10. JavaScript数组方法的兼容性写法 汇总:indexOf()、forEach()、map()、filter()、some()、every()

    ECMA Script5中数组方法如indexOf().forEach().map().filter().some()并不支持IE6-8,但是国内依然有一大部分用户使用IE6-8,而以上数组方法又确实 ...