本系列链接导航:

[独孤九剑]Oracle知识点梳理(一)表空间、用户

[独孤九剑]Oracle知识点梳理(二)数据库的连接

[独孤九剑]Oracle知识点梳理(三)导入、导出

[独孤九剑]Oracle知识点梳理(四)SQL语句之DML和DDL

[独孤九剑]Oracle知识点梳理(五)数据库常用对象之Table、View

[独孤九剑]Oracle知识点梳理(六)数据库常用对象之Procedure、function、Sequence

[独孤九剑]Oracle知识点梳理(七)数据库常用对象之Cursor

[独孤九剑]Oracle知识点梳理(八)常见Exception

[独孤九剑]Oracle知识点梳理(九)数据库常用对象之package

[独孤九剑]Oracle知识点梳理(十)%type与%rowtype及常用函数

5、数据库对象

  Oracle的常用字段类型有:

  • varchar2(128) 用于存储字符,
  • char(4)固定长度的字符串,不设置长度默认值为1,
  • number(p,s)数字型p是位数总长度,s是小树的长度,可存储负数,最长38位,不够位时会四舍五入
  • date 日期和时间类型
  • lob超长字符,最大可达4G
  • clob 超长文本字符串
  • blob超长二进制字符串
  • bfile超长二进制字符串,保存在数据库外的文件里是只读的

5.1、table的操作

5.1.1、创建表时可以给字段加上约束条件

  • 默认值,如date类型的 设置default sysdate,这样每次插入、修改时,不用程序操作这个字段,都能得到动作时间
  • 例如: 非空 NOT NULL
  • 不允许重复 UNIQUE
  • 关键字/主键 PRIMARY KEY
  • 按条件检查 CHECK (条件)
  • 外键 REFERENCES 表名(字段名)

5.1.2、创建表:

 create table person
(
  ID number primary key,
  name varchar2(32),
  gender char default 1
)
tablespace tablespaceName; --设置表空间,不加就默认为当前用户所在表空间 comment on table person is '人员表'; --添加备注
comment on column person.ID is '编号';
comment on column person.name is '姓名';
comment on column person.gender is '性别';

5.1.3、修改表

 rename person to people; --修改表名
alter table person rename column name to xingming; --修改列名
alter table person add phonenumber varchar2(11);--添加列
alter table person add birthday date default sysdate not null; --添加列,设置默认值,不可为空
alter table person drop column phonenumber; --删除列
alter table person modify name varchar2(64); --修改列长度
alter table person modify gender char(2); --修改列精度
alter table person modify gender varchar2(2); --修改列的数据类型
alter table person modify gender default 2;--修改列的默认值

5.1.4、约束操作

  • primary key
alter table person add constraint pk_person_id parmary key(id);--将id列设置为主键
  • foregin key
alter table person add constraint fk_person_gender foreign key(gender); --将gender列设置为外键
  • check
alter table person add constraint ck_person_gender check (gender in (1,2));--检查gender列的值必须在1、2中
  • not null
alter table person modify name constraint not_null_person_name not null;--name列不能为空
  • unique
alter table person add constraint uq_emp_name unique(name); --设置name列唯一约束
  • default
alter table person modify birthday date default sysdate; --设置birthday列的默认值
  • 约束的控制
 --禁用约束
alter table person disable constraint uq_person_name;--禁用uq_person_name这个约束
--启用约束
alter table person enable constraint un_person_name;
--延迟约束
alter table person drop constraint fk_person_gender;
alter table person add constraint fk_person_gender foreign key(gender)
    reference genderInfo(genderNo) deferrable initially deferred;

5.1.5、清除、删除表

 truncate table person where id>10; --清除表person中的数据,不可恢复
delete table person where id>10; --删除表person中的数据,可恢复
drop table person; --删除表

5.2、View的操作

  这里泛指普通视图view,Oracle还包含一种叫物化视图(materialized view)的视图。这里暂不涉及。
  视图分为简单视图( 基于单个基表,且不包含函数和数据分组操作 ) 和复杂视图( 基于多个基表或视图);简单视图可以通过视图修改数据. 这些修改包括插入数据. 更新数据和删除数据. 但是对于复杂视图来说, 通过视图修改数据必须满足一定的规则.

  在视图定义中没有设定READ ONLY 的前提下, 如果视图包含了下面的内容, 那么不能通过视图删除表中的数据:

  1. 分组函数, 如SUM,AVG,MIN,MAX 等 * GROUP BY 子句
  2. 包含了表达式 * ROWNUM 伪列

  [关于通过视图修改数据的操作这里不做介绍]

5.2.1、创建view

 create or replace view v_person --创建或修改视图
[columnName1,columnName2] --设置列名,也可在select中设置别名
as -- 注1
select a.f1,b.f2 from table1 a,table2 b where a.f0=b.f0;

注1:关于Oracl的is和as,

  在存储过程(PROCEDURE)和函数(FUNCTION)中没有区别,
  在视图(VIEW)中只能用AS不能用IS,
  在游标(CURSOR)中只能用IS不能用AS。

5.2.2、union 和union all

  使用union关键字进行合并查询的时候,数据库引擎会自动过滤掉结果集中的重复记录。
  使用union all关键字进行合并查询的时候,数据库引擎就不会过滤结果集中的重复数据,因此在执行效率上将union all比union要高上很多。

5.2.3、删除视图

drop view v_person;

[独孤九剑]Oracle知识点梳理(五)数据库常用对象之Table、View的更多相关文章

  1. [独孤九剑]Oracle知识点梳理(九)数据库常用对象之package

    本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...

  2. [独孤九剑]Oracle知识点梳理(七)数据库常用对象之Cursor

    本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...

  3. [独孤九剑]Oracle知识点梳理(六)数据库常用对象之Procedure、function、Sequence

    本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...

  4. [独孤九剑]Oracle知识点梳理(十)%type与%rowtype及常用函数

    本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...

  5. [独孤九剑]Oracle知识点梳理(二)数据库的连接

    本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...

  6. [独孤九剑]Oracle知识点梳理(八)常见Exception

    本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...

  7. [独孤九剑]Oracle知识点梳理(四)SQL语句之DML和DDL

    本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...

  8. [独孤九剑]Oracle知识点梳理(三)导入、导出

    本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...

  9. [独孤九剑]Oracle知识点梳理(一)表空间、用户

    本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...

随机推荐

  1. ubuntu安装java jdk

    openjdk安装http://openjdk.java.net/install/ 一.下载 首先,当然是要下载了. 地址:http://www.oracle.com/technetwork/java ...

  2. iOS URL Loading System / HTTP 重定向 认识与学习

    一个朋友问了我一个问题,需求是这样的:他要用本地的H5资源 替换 链接资源,  但是判断链接资源时候 因为一些操作请求本地化了之后  一些操作比如请求服务器使用的是http开头,然而本地资源一直是以f ...

  3. css小技巧1

    资料 1. 文本省略 单行省略: white-space:nowrap; overflow:hidden; text-overflow:ellipsis; 多行文本省略: 只兼容webkit内核,不属 ...

  4. VCS 常用命令速查

      VCS是编译型Verilog模拟器,它完全支持OVI标准的Verilog HDL语言.PLI和SDF.VCS具有目前行业中最高的模拟性能,其出色的内存管理能力足以支持千万门级的ASIC设计,而其模 ...

  5. Vue.js学习笔记 第一篇 数据绑定

    双花括号文本插值 先来个最简单的例子,看完之后立马会用Vue了,是不是很有成就感 <!DOCTYPE html> <html> <head> <meta ch ...

  6. SQL Server 利用WITH AS递归获取层级关系数据

    WITH AS短语,也叫做子查询部分(subquery factoring),在SQL Server 2005中提供了一种解决方案,这就是公用表表达式(CTE),使用CTE,可以使SQL语句的可维护性 ...

  7. linux 安装tomcat7

    wget http://mirror.bit.edu.cn/apache/tomcat/tomcat-7/v7.0.81/bin/apache-tomcat-7.0.81.tar.gz 解压安装包 t ...

  8. Could not fetch URL https://pypi.org/simple/pip/: There was a problem confir

    这个问题其实是无意中解决的:因为在网上找不到解决办法,是我在yum -y installl wget后,自动就好了,安装wget的时候,可能更新了openssl的缘故吧.

  9. Maven配置一键部署远程Tomcat

    1. 首先需要配置远程Tomcat的访问权限(设置访问用户名密码) http://www.cnblogs.com/liuchao102/p/5519345.html 2. 配置pom.xml 添加to ...

  10. 【P1582】倒水(数论??暴力!!)

    这个题我很无语,一开始看绿题,还是数论,应该不会特别简单,应该要动笔写上好一会,过了一会旁边 #祝神 说这原来是个蓝题,我顿时觉得十分迷茫... 结果看了这个题看了一会,仔细一想,woc,这题怕不是可 ...