`
changhongbao
  • 浏览: 116811 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

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

阅读更多

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

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

  • 创建对象:CREATE 对象名称 …;
  • 删除对象:DROP 对象名称 …;
  • 修改对象:ALTER 对象名称 …;

一、常用的数据字段

每一张数据表实际上都是由若干个字段所组成,而每一个字段都会有其对应的数据类型,而在Oracle之中,常用的数据类型有如下几种:

数据类型

关键字

描述

1

字符串

VARCHAR2(n)

其中n表示的是字符串所能保存的最大长度,基本上保存200个左右的内容

2

整数

NUMBER(n)

表示最多为n位的整数,有时候也可以使用INT代替

3

小数

NUMBER(n,m)

其中m为小数位,n-m为整数位,有时候也可以使用FLOAT代替

4

日期

DATE

存放日期-时间

5

大文本

CLOB

可以存储海量文字(4G),例如存储《三国演艺》、《红楼梦》

6

大对象

BLOB

存放二进制数据,例如:电影、MP3、图片、文字

一般在开发之中使用最多的:VARCHAR2()、NUMBER、DATE、CLOB,而对于BLOB字段一般使用较少,首先BLOB可以存放4G的二进制数据,但是存放进去之后,一是数据库过于庞大,二是读取不方便;

二、表的创建

如果现在要想进行表的创建,可以使用如下的操作语法:

CREATE TABLE 表名称 (
    字段1 数据类型 [DEFAULT默认值],
    字段2 数据类型 [DEFAULT默认值],
    … …,
    字段n 数据类型 [DEFAULT默认值]
);

下面创建一张成员表(member),有如下保存的信息:姓名、年龄、生日、个人简介。

CREATE TABLE member (
     name VARCHAR2(50) DEFAULT '无名氏',
     age NUMBER(3),
     birthday DATE DEFAULT SYSDATE,
     content CLOB
);

表创建成功之后,下面开始向表中增加数据:

INSERT INTO member(name,age,birthday,content) VALUES('张三',20,TO_DATE('1990-08-12','yyyy-mm-dd'),'一个好人');
INSERT INTO member(age,content) VALUES(20,'一个好人');

一定要再次记住,表的创建是属于数据库对象的创建,所以使用的是CREATE语法。

三、表的复制

在之前学习过表的复制操作,下面给出其完整的操作语法:

CREATE TABLE 复制表名称 AS 子查询;

范例:复制一张只包含20部门雇员信息的表

CREATE TABLE emp20 AS SELECT * FROM emp WHERE deptno=20;

范例:现在要求将emp表的表结构复制出来,不要数据 —— 写一个永远满足不了的条件即可。

CREATE TABLE empnull AS SELECT * FROM emp WHERE 1=2;

但是以上的语法只是Oracle数据库所支持的操作,其他的数据库语法上会有一些区别。

四、为表重命名

在Oracle数据库之中,所有的数据实际上都是通过数据字典保存的,例如,在之前曾经使用过如下的一种查询:

SELECT * FROM tab;

以上就是一个数据字典,而在Oracle之中,提供了三种类型的数据字典,最常用的是:dba_、user_,所以下面查询一个user_tables数据字典:

SELECT * FROM user_tables;

也就是说Oracle中的所有数据都是按照文件保存的,那么所有的内容都会在数据字典中注册,既然这样,所谓的修改表名称实际上对于Oracle而言就相当于修改一条数据而已,而修改表名称的方法如下:

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

范例:将member表更名为person表

RENAME member TO person;

但是这种操作由于是Oracle数据库所独有的一种特性,所以了解即可,不用做深入的掌握。

五、截断表

在之前曾经讲解过一个删除表数据的操作,使用的是DELETE操作,但是这种删除操作本身有一个特点,即:可以进行事务的回滚,也就是说删除之后并不会立刻释放数据的资源,如果现在希望彻底释放掉一张表所占用的全部资源(表空间、索引等等)就可以使用截断表的语法,此语法如下:

TRUNCATE TABLE 表名称;

范例:截断person表

TRUNCATE TABLE person;

但是这种语法本身只是Oracle所有的,所以只做了解即可。

六、表的删除

表的删除操作指的是数据库对象的删除,既然是删除则使用DROP语句,删除表的语法如下:

DROP TABLE 表名称;

范例:删除person表

DROP TABLE person;

七、Oracle 10g的新特性:闪回技术

在Oracle 10g之后,为了预防用户的误删除表操作,专门提供了回收站的功能,用户所删除的表默认情况下会在一个回收站之中保存,而用户也可以通过回收站,进行表的恢复,所以此技术称为闪回(FLASHBACK);

范例:查看回收站

SHOW RECYCLEBIN;

这个时候可以发现所有已经删除的表都在回收站之中保存,那么下面就可以使用如下的语法恢复表:

FLASHBACK TABLE 表名称 TO BEFORE DROP;

范例:恢复myemp表

FLASHBACK TABLE myemp TO BEFORE DROP;

当然,现在也可以直接删除掉回收站中的一些数据表,语法如下:

PURGE TABLE 表名称;

范例:删除回收站中的person表

PURGE TABLE person;

范例:清空回收站

PURGE RECYCLEBIN;

如果现在希望删除一张表,而又不希望其进入到回收站之中,则可以在删除的时候增加PURGE。

DROP TABLE myemp PURGE;

这种技术是在Oracle 10g之后才有的,而Oracle 11g也是存在的。

问题:现在在回收站之中存在了一张tab表,而后又建立了一张tab表,那么如果从回收站中恢复的话,可以吗?

答:无法恢复。

八、修改表结构

如果一张建立好的数据表,发现其初期的结构已经不满足于后期的使用要求,则可以进行表的修改操作,而表的修改操作实际上就是数据库对象的修改操作,使用ALTER指令完成,例如,现在有如下一张表:

CREATE TABLE member (
     mid NUMBER,
     name VARCHAR2(50)
);

现在希望可以向表中增加字段,所以此时可以采用如下的语法完成:

ALTER TABLE 表名称 ADD(列名称 数据类型 [DEFAULT 默认值],
  列名称 数据类型 [DEFAULT 默认值],…);

范例:为member表增加字段

ALTER TABLE member ADD(age NUMBER(3), birthday DATE DEFAULT SYSDATE);

如果增加的数据列没有默认值,则所有已有的数据的列的内容都是null,而如果增加的列指定了DEFAULT默认值的话,则所有已有的数据列都是设置的默认值。

现在也可以修改已有的表结构,此时的语法如下:

ALTER TABLE 表名称 MODIFY(列名称 数据类型 [DEFAULT 默认值],
  列名称 数据类型 [DEFAULT 默认值],…);

范例:将name字段的默认值定义为无名氏

ALTER TABLE member MODIFY(name VARCHAR2(100) DEFAULT '无名氏');

虽然在SQL语法之中以及Oracle数据库之中,都给出了修改表结构的操作,但是这种操作能不使用就不使用,从大型数据库来讲,世界上性能最高的数据库是IBM DB2,但是IBM DB2本身有一个平台的限制问题,所以如果说是跨平台的数据库则是Oracle数据库的性能最高。

在IBM DB2数据库之中是不允许修改表结构的,即:表建立完成之后就不能修改了,所以以后在开发之中也尽可能的不要去修改表结构。

九、思考题

现在要求建立一张nation表,表中有一个name字段,里面保存四条记录:中国、美国、巴西、荷兰,要求通过查询实现如下的操作效果:

中国         美国

中国         巴西

中国         荷兰

美国         巴西

美国         中国

美国         荷兰

剩下的依次类推,现在要求建立新的表并完成此查询的操作。

本题目的主要目的并不是在于查询的编写上,而是在于规范化数据库创建脚本的格式,以后只要是碰到了类似的要求,首先必须编写一个数据库创建脚本,这个脚本的要求如下:

1、  本文件的文件名称后缀必须是“*.sql”;

2、  先删除相应的数据表;

3、  编写创建表的语句;

4、  增加测试数据;

5、  提交事务;

复制代码
--1、删除表
DROP TABLE nation PURGE;
--2、创建表
CREATE TABLE nation(
    name VARCHAR2(50)
);
--3、测试数据
INSERT INTO nation(name) VALUES('中国');
INSERT INTO nation(name) VALUES('美国');
INSERT INTO nation(name) VALUES('巴西');
INSERT INTO nation(name) VALUES('荷兰');
--4、事务提交
COMMIT;
复制代码

本程序如果要想完成依靠笛卡尔积完成,属于表的自身关联。

SELECT n1.name,n2.name
FROM nation n1,nation n2
WHERE n1.name<>n2.name;

而且以后如果面试之中,出现了一些复杂的查询,建议把脚本写全了。

分享到:
评论

相关推荐

    oracle笔记创建和管理表

    oracle笔记创建和管理表,增加列,删除列,修改列,修改列名和数据类型和长度,修改表名等等操作,有代码案例!

    Oracle 10g 学习笔记

    最新最全的Oracle10g学习笔记,Oracle的基本使用--基本命令oracle用户管理oracle表的管理(数据类型,表创建删除,数据CRUD操作oracle表查询

    oracle笔记

    oracle的笔记 oracle的安装 各种查询语句的讲解 表的创建和管理希望对大家有帮助

    Oracle 12c体系结构学习实验笔记

    Oracle 12c实验-管理表空间.pdf Oracle 12c实验-管理归档重做日志.pdf Oracle 12c实验-管理控制文件.pdf Oracle 12c实验-管理数据文件和临时文件.pdf Oracle 12c实验-管理重做日志.pdf Oracle 12c实验-归档模式&非...

    韩顺平oracle学习笔记

    韩顺平oracle学习笔记 第0讲:如何学习oracle 一、如何学习oracle Oracle目前最流行的数据库之一,功能强大,性能卓越。学习oracle需要具备一定基础: 1.学习过一门编程语言(如:java ,c) 2.最好学习过一门别的...

    oracle使用管理笔记(一些经验的总结)

    8.oracle表管理 12 9.oracle基本查询 14 oracle基本所有查询案例 16 10.oracle分页查询 21 (1)删除重复记录 22 11.oracle合并查询 24 12.oracle连接 25 13.oracle函数 26 (1)字符函数 26 (2)数学函数 26 (3)日期函数...

    oracle所有知识点笔记(全)

    这是我自己学习oracle的时候,写的代码案例和笔记,基本上每一个知识点都写的很清楚!大家可以作为参考! 该有的知识点都有! 基本的sql语法,触发器,存储过程,存储函数...约束,创建和管理表,单行函数,过滤数据等等

    oracle学习文档 笔记 全面 深刻 详细 通俗易懂 doc word格式 清晰 连接字符串

    其三、职业方向多:Oracle数据库管理方向、Oracle开发及系统架构方向、Oracle数据建模数据仓库等方向。 四、 如何学习 认真听课、多思考问题、多动手操作、有问题一定要问、多参与讨论、多帮组同学 五、 体系结构 ...

    韩顺平玩转oracle视频教程笔记

    概述:在oracle中要创建一个新的用户使用create user语句,一般是具有dba(数据库管理员)的权限才能使用。 create user 用户名 identified by 密码; (oracle有个毛病,密码必须以字母开头,如果以字母开头,它不会...

    Oracle9i备课笔记——吕海东

    Oracle9i备课笔记——吕海东 第1讲 Oracle9i简介 目的: 1. 了解数据库的发展,关系数据库的基本原理。 2. 了解目前市场上流行的数据库产品及特点 3. 了解Oracle数据库的发展 4. 掌握Oracle9i产品系列 5. 掌握Oracle...

    oracle实用教程-韩顺平

    4.oracle 表的管理(数据类型,表创建删除,数据 CRUD 操作) 5.oracle 表查询(1) 6.oracle 表查询(2) 7.java 操作 oracle 8.oracle 中事务处理 9.oracle 的函数 10.数据库管理,表的逻辑备份与恢复 11.数据字典和...

    全新Oracle OCA认证体系DBA实战课 刘Sir Oracle数据库OCA认证培训视频课程

    课程想以介绍了Oracle认证体系,详细带领同学们进行Oracle实战环境搭建,Oracle体系结构,Oracle数据库创建于安装,管理ASM实力实战,数据并发与控制,实施oracle数据库的审计,数据库的性能管理,备份恢复与数据库...

    oracle数据库笔记

    Oracle 10g 开发与管理 本文是由笔者2012年学习oracle数据库时编写的学习札记,其中的题目 多数为老师留下的思考题目。 我相信本文会对初学者使用oracle有一个初步的使用印象。右图为我所参 考的书籍。 第一...

    Oracle RAC(Real Application Clusters)集群搭建笔记

    以下是基于提供的参考信息整理出的Oracle RAC集群搭建的详细笔记: ### 1. 安装前的规划 - **系统规划**:确保所有节点硬件配置相同,操作系统版本一致。建议使用相同的CPU、内存和网络硬件。 - **网络规划**:配置 ...

    oracle学习笔记(三)

    一、创建和管理表 1、创建表语法 create table 表名(column datatype [default expr][,column …]) default 约束 说明略 2、利用子查询创建表 create table 表名 as select * from u表 二、修改表 1、添加一个新列 ...

    ORACLE文件集

    本人学习ORACLE的一些记录笔记,其中包括PL/SQL语言、表空间管理、创建数据库等

    mariadb学习笔记

    Mariadb学习笔记,MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可 MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能轻松成为MySQL的代替品。在存储引擎方面,使用XtraDB...

    Navicat Premium操作手册.7z

    3Oracle 外部表访问参数59Oracle 索引组织表59Oracle 索引组织表选项59Oracle ...Oracle 表空间77Oracle 公用数据库链接80Oracle 公用同义词80PostgreSQL 对象80PostgreSQL 模式81PostgreSQL 表81PostgreSQL 表栏位81...

    [小e笔记]之10gR2+redhat5.3+32bit+RAC安装

    目录 1 操作系统环境 3 1.1 RAC操作系统环境 3 ...4.2配置Oracle自动存储管理(ASM) 51 5 安装Clusterware 52 5.1 检查安装环境 52 5.2 开始安装crs 53 6 安装database软件 67 7 创建数据库和ASM实例 76

Global site tag (gtag.js) - Google Analytics