/*-----------------------创建和管理表-----------------------------*/
一、Orcale之中的数据类型:
1.NUMBER、DATE、VARCAHR、CLOB、BLOB

二、表的建立
CREATE TABLE 表名称(
 字段名1  字段类型  [DEFAULT 默认值],
 字段名2  字段类型  [DEFAULT 默认值],
 ...
 字段名N  字段类型  [DEFAULT 默认值]
);

CREATE TABLE 表名称 AS(子查询)
·如果子查询写的是 SELECT * FROM emp,表示把表结构和表内容一起复制
·如果子查询写的是 SELECT * FROM WHERE 1==2,加入了一个永远不成立的条件,则表示只复制表结构,不复制内容!

三、表单的删除
DROP TABLE 表名称

四、表的修改
1、增加列:
·ALTER TABLE 表名称 ADD(列的名称 列的类型 DEFAULT 默认值,...);
 ALTER TABLE person ADD(address VARCHAR(200) DEFAULT'暂无地址');
2、修改列:
·ALTER TABLE 表名称 MODIFY(列的名称 列的类型 DEFAULT 默认值)
 ·但是,在修改表结构的时候,如果假设数据中对应的字段里有一个很长的数据,是无法将表的长度缩小的

五、表的重命名[Orcale特有]
·RENAME 命令:RENAME 旧的表名  TO  新的表名;

六、截断表
清空表数据,但是希望立刻清空,而不需要rollback,commit之类的
TRUNCATE TABLE 表名称;

七、表约束【重点】
·主键约束:主键表示唯一的标识,本身不能为空,不可重复
·唯一约束:在一个表之中只允许建立一个主键约束,其他表如果希望不能出现重复值的话,则可以用唯一约束
·检查约束:检查一个列的内容是否合法  NUMBER(5)
·非空约束:NOT NULL
·外键约束:在两张表进行约束的操作

范例:
DROP TABLE person;  --删除
CREATE TABLE person(  --创建
pid VARCHAR(18)  PRIMARY KEY,
name VARCHAR(200),
age NUMBER(3) NOT NULL CHECK(SEX IN('男','女')),--非空约束 检查约束
birthday DATE,
sex VARCHAR(2) DEFAULT '男'
CONSTRAINT person_pid_key PRIMARY KEY(pid); --主键
CONSTRAINT person_name_unique UNIQUE(name); --唯一约束
CONSTRAINT person_age_ck CHECK(age BETWEEN 0 AND 150)  --检查约束
);

1、主键约束(PRIMARY KEY)
·可以在建立表的时候加你,默认不能为空且不能后重复!
·也可以在建表后再加入:
 指令  约束别名 约束
 CONSTRAINT person_pid_pk PRIMARY KEY(pid)

2、非空约束:和主键一样能够在建表时候添加,也可以在之后添加,NOT NULL

3、唯一约束(UNIQUE):表示唯一约束,也能在建表时候添加

4、检查约束(CHECK):判断插入的内容是否合法
例:年龄 CHECK(SEX IN('男','女'))
年龄  CHECK(age BETWEEN 0 AND 150)

5、外键约束(FOREGIN KEY):
CONSTRAINT person_book_pid_fk FOREGIN KEY(pid) REFERENCES person(pid) ONDELETE CASCADE;
表示级联删除

七、修改约束:
·如果一个表已经建立完成了之后,则可以为其添加约束。
CREATE TABLE person(
pid  VARCHAR(18) ,
name  VARCHAR(200),
age  NUMBER(3),
birthday DATE,
sex  VARCHAR(2) DEFAULT '男'
);

ALTER TABLE 表名称 ADD CONSTRAINT 约束名  约束类型(约束字段);
命名规范:
·PRIMARY KEY :主键字段_PL
·UNIQUE:  主键_UK
·CHECK: 主键_CK
·FOREIGN KEY:  父字段_子字段_FK

ALTER TABLE person ADD CONSTRAINT person_age CHECK(age BETWEEN 0 AND 150);
ALTER TABLE book ADD CONSTRAINT person_book_pid_fk FOREIGN KEY(pid) REFERENCES person(pid) ONDELETECASDE;

八、删除约束 上面的ADD修改成DROP

ALTER TABLE person DROP CONSTRAINT person_age CHECK(age BETWEEN 0 AND 150);

九、ROWNUM(重点)
ROWNUM其实是在查询之后才给定的编号
表示行号,实际上此是一个列,一个伪列,此列在任意表之中存在
SELECT ROWNUM,ename FROM emp;
    ROWNUM ENAME
---------- ----------
         1 ALLEN
         2 WARD
         3 JONES
         4 MARTIN
         5 BLAKE
         6 CLARK
         7 SCOTT
         8 KING
         9 TURNER
        10 ADAMS
        11 JAMES
        12 FORD
        13 MILLER

ROWNUM不能使用BETWEEN n AND m 来进行截取。如果想要进行中间截取
则只能采用子查询。

SELECT *
FROM (SELECT ROWNUM rn,e.* FROM emp e WHERE ROWNUM<=10) temp
WHERE temp.rn>5;

这样才能够显示6-10的数据

Oracle表管理的更多相关文章

  1. 五、oracle 表管理

    一.表名和列名的命名规则1).必须以字母开头2).长度不能超过30个字符3).不能使用oracle的保留字4).只能使用如下字符 a-z,a-z,0-9,$,#等 二.数据类型1).字符类char 长 ...

  2. Oracle 表管理 约束 索引

    表的约束与完整性: 1.实体完整性 主键唯一性 2.域完整性 不能向number中插入varchar 3.参照完整性 外键 以别的表的字段作为外键,再插入该表时所插入外键的值必须在被参照表中该字段有那 ...

  3. OracleDBA之表管理

    下面是Oracle表管理的部分,用到的测试表是oracle数据库中scott用户下的表做的测试,有的实验也用到了hr用户的数据,以下这些东西是我的麦库上存的当时学Oracle的学习笔记今天拿出来和大家 ...

  4. Oracle表空间管理

    oracle表空间相关常用命令小结: 1.ALTER DATABASE SET DEFAULT BIGFILE TABLESPACE;              //修改表空间数据文件类型 2.ALT ...

  5. Oracle的学习二:表管理(数据类型、创建/修改表、添加/修改/删除数据、数据查询)

    1.Oracle表的管理 表名和列名的命名规则: 必须以字母开头: 长度不能超过30个字符: 不能使用oracle的保留字: 只能使用如下字符:A-Z, a-z, 0-9, $, # 等. Oracl ...

  6. oracle 表空管理方式(LMT)、ASSM段管理方式、一级位图块、二级位图块、三级位图块。

    今天是2013-12-16,今天和明天是我学习oracle生涯中一个特殊的日子.今天晚上进行了一下表空间管理方式的学习,在此记录一下笔记. 对于oracle数据库最小i/0单位是数据块,最想分配空间单 ...

  7. Oracle 表空间的日常维护与管理

    目录 Oracle 表空间的日常维护与管理 1.创建数据表空间 2.创建临时表空间 3.创建 UNDO 表空间 4.表空间的扩展与修改大小 5.表空间重命名 6.表空间的删除 7.更改表空间的读写模式 ...

  8. Oracle表空间概述及其基本管理

    最近在工作中遇到有同事对Oracle表空间的理解有问题,所以写了这篇文章.我会从概念,管理及特别需要关注的点等几个维度对表空间进行一些介绍.本文以介绍表空间为主,涉及到的其他概念不展开描述.有问题的地 ...

  9. Oracle 表结构管理

    表其实是数据的'容器'.oracle有几种类型的表: 普通表(ordinary table)又叫堆组织表. 聚簇表(clustered table) 分区表(partition table) 外部表( ...

随机推荐

  1. 【C/C++】Linux下使用system()函数一定要谨慎

    [C/C++]Linux下使用system()函数一定要谨慎 http://my.oschina.net/renhc/blog/53580 曾经的曾经,被system()函数折磨过,之所以这样,是因为 ...

  2. springMVC3学习(四)--訪问静态文件如js,jpg,css

    假设你的DispatcherServlet拦截的是*.do这种URL.就不存在訪问不到静态资源的问题 假设你的DispatcherServlet拦截了"/"全部的请求,那同一时候对 ...

  3. LSH算法原理

    原始链接--http://www.jiahenglu.net/NSFC/LSH.html LSH(Location Sensitive Hash),即位置敏感哈希函数.与一般哈希函数不同的是位置敏感性 ...

  4. Erp第一章:初感

    Erp第一章:初感1.核心标志实现:内部集成.外部集成.内部集成包括实现产品研发.核心业务.数据采集:外部集成就是企业与供需链上的所有合作伙伴的共享信息集成.2.Erp难点在于打破传统企业四面墙,把流 ...

  5. 什么是HTTP Keep-Alive呢?

    在通过调试工具查看网络请求的时候,通常在response header能看到类似下面这种:Keep-Alive: timeout=10, max=94 .那么Keep-Alive到底是什么呢? HTT ...

  6. UVA 1153 KEEP THE CUSTOMER SATISFIED

    题意: 钢铁公司有N个客户的订单,每个订单有一个产量q(生产时间刚好也等于q)和订单完成截止时间.公司要求完成尽量多的订单. 分析: 先按截止时间d排序,然后维护一个已经选好的订单的优先队列,如果当前 ...

  7. 【转】Android的线程使用来更新UI----Thread、Handler、Looper、TimerTask

    方法一:(java习惯,在android不推荐使用) 刚刚开始接触android线程编程的时候,习惯好像java一样,试图用下面的代码解决问题 new Thread( new Runnable() { ...

  8. .Net 发邮件

    对于.NET而言,从2.0开始,发邮件已经是一件非常easy 的事了.下面我给出一个用C#群发邮件的实例,做了比较详细的注解,希望对有需要的朋友有所help. // 引入命名空间using Syste ...

  9. centOs下的php+mysql+apache+ftp配置

    在安装服务器时做了相应的笔记,这个方法是亲身经验成功的,随着版本的不断更新,也许会有一些地方不同,但是基本原理都是一样的. 1.安装CentOS 6 ,可以选择最小安装,也可以安装桌面 2.升级系统 ...

  10. PDO的事物处理机制

    Mysql的事务处理: 1.MySQL目前只有InnoDB 和BDB两个数据表类型才支持事务. 2.在默认条件下,MySQL是以自动提交(autocommit)模式运行的,这就意味着所执行的每一个语句 ...