Oracle数据库之创建表结构

主键与外键

主键:关系型数据库中的一条记录中有若干个属性,若其中的某一个属性组(可以是一个属性,也可以是多个)能唯一标识一条记录,那么该属性组就是主键。

外键:关系型数据库表中的一列或者某几列的组合,它的值与另外一张表的某一列或者某几列相匹配,且为另一张表的主键(即这张表的某一列或某几列是另外一张表的主键,称这一列或几列为另外一张表的外键)。

注意:

  1. 一张表主键只能有一个,可以有多个外键以及唯一索引
  2. Oracle数据库共有5个约束:主键、外键、非空、唯一、条件 
    • 非空:这个列的值不能为空(NOT NULL)
    • 唯一:这个列的值在表中是唯一存在的,不能重复,但可以为空值(NULL)
    • 条件:可以对列的值设定在某个范围内,如人的年龄就不能为负数等。
  3. 主键和唯一约束的区别:主键是列的值为表中的唯一标识,不能为空值(NULL),而唯一约束是列的值在表中唯一存在,可以为空值(NULL)。

表的创建

语法结构:

CREATE TABLE [schema.]table_name
(column datatype [constraint-clause][, column datatype [constraint-clause]] … )
[TABLESPACE tablespace]
[PCTFREE integer]
[PCTUSED integer]
[INITRANS integer]
[MAXTRANS integer]
[STORAGE storage-clause]
[LOGGING|NOLOGGING]
[CACHE|NOCACHE] ];

说明:

  • schema:表的所有者
  • table_name:表名
  • column:字段名
  • datatype:字段的数据类型
  • constraint-clause:列约束说明
  • tablespace:表所在的表空间
  • PCTFREE:为了行长度增长而在每个块中保留的空间的量(以占整个空间减去块头部后所剩余空间的百分比形式表示),当剩余空间不足pctfree时,不再向该块中增加新行。
  • PCTUSED:在块剩余空间不足pctfree后,块已使用空间百分比必须小于pctused后,才能向该块中增加新行。
  • INITRANS:在块中预先分配的事务项数,缺省值为1
  • MAXTRANS:限定可以分配给每个块的最大事务项数,缺省值为255
  • STORAGE:标识决定如何将区分配给表的存储子句
  • LOGGING:指定表的创建将记录到重做日志文件中。它还指定所有针对该表的后续操作都将被记录下来。这是缺省设置。
  • NOLOGGING:指定表的创建将不被记录到重做日志文件中。
  • CACHE:指定即使在执行全表扫描时,为该表检索的块也将放置在缓冲区高速缓存的LRU列表最近使用的一端。
  • NOCACHE:指定在执行全表扫描时,为该表检索的块将放置在缓冲区高速缓存的LRU列表最近未使用的一端。
  • STORAGE子句:
  • INITIAL:初始区的大小
  • NEXT:下一个区的大小
  • PCTINCREASE:以后每个区空间增长的百分比
  • MINEXTENTS:段中初始区的数量
  • MAXEXTENTS:最大能扩展的区数

常用建表示例:

-- 无约束
CREATE TABLE Items(
ItemNO number(2),
ItemName varchar2(20)
);
-- 主键约束
CREATE TABLE Items(
ItemNO number(2) constraint PK_Items primary key,
ItemName varchar2(20) not null
);
-- 外键约束
CREATE TABLE Business(
BusiNo number(2) constraint PK_Business primary key,
BusiName varchar2(32) not null,
ItemNO number(2),
StartTime date,
constraint FK_Business foreign key(ItemNO) references Items(ItemNO)
);
-- “唯一”和“条件”约束
CREATE TABLE Computers(
CompNo number(4) constraint PK_Comp primary key,
CompModel varchar2(64) unique,
BuyTime date,
Price number(7,2) constraint ch_price check(price>0 and price<=30000),
Owner varchar2(32));

注意:

constraint:定义表中约束所必须的关键字

primary key:主键约束关键字

foreign key…references…:创建表的外键关键字

unique:为唯一约束关键字

constraint…check…:为条件约束的关键字

一个完整的示例:

CREATE TABLE Employee(
id NUMBER(5) CONSTRAINT pk_employee_id PRIMARY KEY,
last_name VARCHAR2(10) CONSTRAINT employee_last_name_nn NOT NULL,
first_name VARCHAR2(10) NOT NULL UNIQUE,
userid VARCHAR2(8) CONSTRAINT un_employee_userid UNIQUE,
start_date DATE DEFAULT SYSDATE,
title VARCHAR2(10),
dept_id NUMBER(7) CONSTRAINT fk_employee_dept_id REFERENCES dept(id),
salary NUMBER(11,2),
user_type VARCHAR2(4) CONSTRAINT ck_employee_user_type CHECK (user_type IN('IN','OUT')),
CONSTRAINT employee_uq_title UNIQUE (title,salary)
)
TABLESPACE tsb_01
INITRANS 1
MAXTRANS 255
PCTFREE 20
PCTUSED 50
STORAGE (INITIAL 1024K NEXT 1024K PCTINCREASE 0 MINEXTENTS 1 MAXEXTENTS 5)

删除表

DROP TABLE employee;

修改表

-- 修改表的名称
RENAME Items TO OrderItems;
-- 显示表结构
DESC OrderItems;
-- 增加列
ALTER TABLE test ADD address varchar2(40);
-- 删除列
ALTER TABLE test DROP COLUMN address;
-- 修改列的名称
ALTER TABLE test MODIFY address addresses varchar(40);
-- 修改列的属性
ALTER TABLE Emp modify score not null;

添加约束,语法如下:

ALTER TABLE 表名称 ADD CONSTRAINT 约束名称 约束类型(约束字段) 
-- 示例
ALTER TABLE Dept ADD CONSTRAINT pk_dept primary key(id);
ALTER TABLE Dept ADD CONSTRAINT fk_dept_comp foreign key(companyid) references Company;

删除约束,语法:

ALTER TABLE 表名称 DROP CONSTRAINT 约束名称;    
-- 示例
ALTER TABLE book DROP CONSTRAINT fk_book_pid;

Oracle数据库之创建表结构的更多相关文章

  1. Oracle数据库之创建表空间与用户

    Oracle数据库之创建表空间与用户 一.创建表空间 基本语法表述: CREATE TABLESPACE tablespace_name [DATAFILE datafile_spec1 [,data ...

  2. oracle 数据库下所有表结构、数据量及缺失值统计

    表结构 SELECT t1.TABLE_NAME, t1.COLUMN_NAME, t1.DATA_TYPE || '(' || t1.DATA_LENGTH || ')', t2.COMMENTS ...

  3. 如何导出远程oracle数据库中的表结构

    从远程oracle数据库上导出指定表的表结构语句有两种方法: 方法一:通过sql语句获得 1,make sure that you can connect the remote database. 2 ...

  4. Oracle数据库不能创建表空间及表中文乱码问题

    1.不能创建表空间问题 datafile为表空间的存放位置,没有将表空间存放路径指定为orcl数据库时,创建表空间出错如下 查看自己的Oracle安装位置,我的Oracle10g安装在虚拟XP系统中, ...

  5. oracle数据库如何创建表空间,临时表空间

    目标 1.创建表空间 lxy 2.创建临时表空间tmp_lxy create tablespace lxy datafile '/u01/app/oracle/oradata/LXY/lxy.dbf' ...

  6. oracle数据库中创建表空间和临时表空间,以及用户和密码以及设置密码永不过期

    首先进入oracle用户,命令是: su - oracle sqlplus /nolog connect system/123456@ora11g 或者 [oracle@localhost ~]$   ...

  7. Oracle数据库中创建表空间语句

    1:创建临时表空间 create temporary tablespace user_temp tempfile 'Q:\oracle\product\10.2.0\oradata\Test\xyrj ...

  8. 使用sql developer 导出Oracle数据库中的表结构

    MS SQLServer的客户端工具做的的确比较好,直接右键,导出数据库就OK了,而且MS的客户端导出的是xxx.dbf文件,直接附加到别的数据库上就OK了 Oracle的sql developer就 ...

  9. Oracle数据库的创建表全

    CREATE TABLE "库名"."表名" ( "FEE_ID" VARCHAR2(10 BYTE) constraint ABS_FEE ...

随机推荐

  1. poj 2516Minimum Cost

    http://poj.org/problem?id=2516 #include<cstdio> #include<cstring> #include<algorithm& ...

  2. UOJ #78 二分图最大匹配

    #78. 二分图最大匹配 从前一个和谐的班级,有 nl 个是男生,有 nr 个是女生.编号分别为 1,…,nl 和 1,…,nr. 有若干个这样的条件:第 v 个男生和第 u 个女生愿意结为配偶. 请 ...

  3. 【转】Android点击空白区域,隐藏输入法软键盘

    原文网址:http://www.2cto.com/kf/201505/401382.html 很多时候,我们在使用应用时,会出现输入法软键盘弹出的问题,通常情况下,我们默认会使用户点击返回键或者下一步 ...

  4. sicily 1119 Factstone Benchmark

    题意:求满足n! < 2^k,n的最大值! 解题:指数比较转换成对数比较,达到降幂! 其中: log (n!) = log(n)+log(n-1)+...+log(1); log(2^k) = ...

  5. des加密解密源码 C# key值问题

    公司协议安全需求.需要对传输内容做des.md5加密. 因为是新人.刚交给我这个任务的时候有点眩晕.就开始在网上找各种des加密的内容.因为不懂以为需要把原理也搞明白,最后误了时间.把自己也搞糊涂了. ...

  6. 使用MyEclipse搭建java Web项目开发

    转自:http://blog.csdn.net/jiuqiyuliang/article/details/36875217 首先,在开始搭建MyEclipse的开发环境之前,还有三步工具的安装需要完成 ...

  7. windows 编程 —— 子窗口 与 子窗口控件

    目录: 子窗口与主窗口的交互 子窗口控件 按钮类别 button 滚动条类别 scrollbar 静态类别  static 编辑框类别 edit 清单方块 listbox 子窗口与主窗口的交互 创建窗 ...

  8. swift - use backslash to add the value in the string

    There’s an even simpler way to include values in strings: Write the value in parentheses, and write ...

  9. asp.net using library ClosedXML to export excel

    Reference:  http://closedxml.codeplex.com/ 1. First add refenrence ClosedXML.dll and DocumentFormat. ...

  10. 10 Powerful Apache Modules--reference

    Apache is the most popular web server in the world,because it is more efficient than others.Thrust o ...