Oracle笔记-表的管理

3.1创建和管理表
在Oracle表中使用的emp,dept,sal都是系统内建好的表,那么在
SQL语法中同样支持了表的创建语句,要想创建表,则应先了解下Oracle
中最常用的几种数据类型
3.1.1常用的数据类型--(重点)
常用的数据类型,如之前的emp表中已经出现了三种
NUMBER(n):表示一个整数,数字长度是n,可以使用int代替
NUMBER(m,n):表示一个小数,小数长度为n,整数长度为m-n,可以使用FLOAT代替
VARCHAR/VARCHAR2::表示的是一个字符串,有长度限制,为255
DATE:表示日期的类型,日期要按照标准的日期格式进行存放
CLOB:大对象,表示大文本数据,一般可以存放4G的文本
BLOB:大对象,表示二进制数据,最大可以存放4G,例如:存放电影,歌曲,图片
3.1.2表的建立--(重点)
表的建立按照标准的语法进行,但是在表的建立时候有时会指定约束,那么此处先给出一个来建立的一个简单语法
表的建立语法
CREATE TABLE 表名称(
字段名称1 字段类型 [DEFAULT 默认值],
字段名称2 字段类型 [DEFAULT 默认值],
...
字段名称n 字段类型 [DEFAULT 默认值]

之前学习过复制表的语法--------------------------------------------------
CREATE TABLE 表名称 AS (子查询)
--如果现在子查询写的是 select * from emp,表示将表结构和表内容一起复制
--如果现在子查询、写的是 select * from emp where1=2,加入了一个永远不可能成立的条件,则此时表示的只是复制表结构,但是不复制表内容

CREATE TABLE tmp AS(SELECT * FROM emp WHERE 1=2);

SELECT * FROM tmp;

例子:创建表
CREATE TABLE person
(
pid VARCHAR2(18),
NAME VARCHAR2(200),
age NUMBER(3),
birthday DATE,
sex VARCHAR2(2) DEFAULT ‘男‘
);

SELECT * FROM person;

像表中插入数据
INSERT INTO person(pid,NAME,age,birthday,sex)VALUES
(‘1111111111‘,‘张三‘,30,to_date(‘1976-02-13‘,‘yyyy-mm-dd‘),‘女‘);

SELECT * FROM person;

SELECT to_date(‘1889-09-12‘,‘yyyy-mm-dd‘) from dual;

INSERT INTO person(pid,NAME,age,birthday) VALUES
(‘22222222‘,‘李四‘,31,to_date(‘1975-02-13‘,‘yyyy-mm-dd‘));--sex默认了,两下都不要写

如果现在希望在表中增加一个address的字段,则可以将表先删除之后再重新创建

3.1.3表的删除--(重点)
DROP TABLE 表名称
例子:删除person表
DROP TABLE person;
重新编写新的脚本
CREATE TABLE person
(
pid VARCHAR2(18),
NAME VARCHAR2(200),
age NUMBER(3),
birthday DATE,
sex VARCHAR2(2) DEFAULT ‘男‘,
adress VARCHAR(200)
);

SELECT * FROM person;

如果现在假设一个表中已经存在了大量的记录,再删除的话,是不是很麻烦,
所以在SQL语句之中提供了专门修改表结构的命令。增加列,修改列。
3.1.4表的修改(了解)
--在一般的数据库程序开发中,很少去修改表结构,这一点在IBM DB2数据库中就没有
--提供alter table指令,所以在建表的时候一定要考虑到位
在SQL语法操作中,提供了ALTER指令,通过ALTER指令就可以增加新的列。
例如:为最早的person表中增加一个address列
--数据库脚本指删除,创建,测试数据

DROP TABLE person;

CREATE TABLE person
(
pid VARCHAR2(18),
NAME VARCHAR2(200),
age NUMBER(3),
birthday DATE,
sex VARCHAR2(2) DEFAULT ‘男‘
);

INSERT INTO person(pid,NAME,age,birthday,sex)VALUES
(‘1111111111‘,‘张三‘,30,to_date(‘1976-02-13‘,‘yyyy-mm-dd‘),‘女‘);

INSERT INTO person(pid,NAME,age,birthday) VALUES
(‘22222222‘,‘李四‘,31,to_date(‘1975-02-13‘,‘yyyy-mm-dd‘));

ALTER TABLE 表名称 ADD(列的名称 列的类型 DEFAULT 默认值,列的名称 列的类型 DEFAULT 默认值,。。。)

ALTER TABLE person ADD(address VARCHAR2(200 ) DEFAULT ‘暂无地址‘ )

现在假设修改person中name字段的值,为name的长度修改为50,默认值为”无名氏“

ALTER TABLE 表名称 MODIFY(列的名称 列的类型 DEFAULT 默认值)
--但是在修改表结构的时候。如果假设数据库中对应的字段里有一个很长的数据,则无法将表的长度缩小
--例如现在name字段中存在一个长度为20个字符的字母,原本的name可以容纳200个内容,但是此时要将name字段的长度修改为10,则肯定无法实现

例子:修改person表中的name列,加入默认值,修改大小

ALTER TABLE person MODIFY (NAME VARCHAR2(20)DEFAULT ‘无名氏‘);

例子:再向表中插入数据,但是不插入姓名和内容

INSERT INTO person(pid,age,birthday) VALUES
(‘22222222‘,31,to_date(‘1975-02-13‘,‘yyyy-mm-dd‘));

--从以上的操作结果中发现身份证编号重复了,是因为没有约束条件

3.1.5为表重命名(了解)
--在Oracle中提供了rename命令,可以为表重新进行命名,但是此语句只能在Oracle照片那个使用

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

例子:将person表重命名为tperson

RENAME person TO tperson;

SELECT * FROM tperson;

3.1.6截断表

如果现在person表中的一条数据使用delete语句删除了,即可通过rollback进行回滚,如果现在假设想要清空一张
表的数据,但是同时又不需要回滚,可以立刻释放资源就需要使用截断

TRUNCATE TABLE 表名称;
例子:截断tperson表

TRUNCATE TABLE tperson;--立刻释放资源

SELECT * FROM tperson;

时间: 2024-08-09 14:40:47

Oracle笔记-表的管理的相关文章

Oracle笔记之权限管理

权限管理 1,默认的三个用户 2,创建用户 3,授权,撤销权限 4,系统权限与对象权限 5,角色 6,通过角色对权限进行管理 7,权限的传递,丢失管理员密码怎么办 3个默认的用户 用户名        密码 sys            change_on_install system      manager scott          tiger cmd 进入命令行 sqlplus / as sysdba; 或者 sqlplus sys/change_on_install as sysdb

第15章 oracle undo表空间管理

2015-10-23 目录 参考资料 [1] 林树泽.Oracle 11g R2 DBA操作指南[M].北京:清华大学出版社,2013 [2] Oracle undo 表空间管理 [3] undo表空间概述 [4] Oracle UNDO表空间的管理 [5] Oracle的UNDO表空间管理总结 [6] UNDO表空间的管理 [7] UNDO表空间的管理 [8] 监控和管理Oracle UNDO表空间的使用 [9] 谈谈undo表空间

Oracle外部表的管理和应用

外部表作为oracle的一种表类型,虽然不能像普通库表那么应用方便,但有时在数据迁移或数据加载时,也会带来极大的方便,有时比用sql*loader加载数据来的更为方便,下面就将建立和应用外部表的命令和操作记录如下: --创建存放文件的directory对象 sqlplus username/[email protected] create directory ex_data as '/home/ex_data/'; --创建外部表 CREATE TABLE tab1_ex ( C1 VARCHA

Oracle建表插数据等等

Oracle的表的管理:表名和列的命名规则 . 必须以字母开头 . 长度不能超过30个字符 . 不能使用Oracle的保留字 . 只能使用如下字符 column_name-Z,column_name-z,0-9,$,#等 Oracle支持的数据类型 字符类:char 定长,最大2000个字节. 例子:char(10) 如果内容为'小杰'则前四个字节放'小杰',后添6个空格补全varchar2() 变长 最大4000个字符. 例子:varchar2(10) '小杰',Oracle分配四个字符.这样

oracle学习笔记之用户管理-3

用户权限机制 1.不同用户表权限的赋予 grant select on scott.emp to software; ---当前登录用户为表所有者,则表名前不用指定所属用户 2.用software登录后 select * from scott.emp; ---software才有权限查询到scott的emp表 方案(schema) 当用户创建好后,如果该用户创建了一个数据对象(如表),此时dbms会创建一个对应的方案与改用户对应,并且该方案的名称和用户名称一致. system与scott都拥有自

oracle学习笔记之用户管理-2

案例:创建一个用户software,然后给分配权限,可以让software登录数据库.创建表.操作自己创建的表,回收角色,最后删除用户. 1.创建software用户,密码system create user software identified by system; 2.让software连接数据库,需要给其connect.resource权限 grant connect to software; grant resource to software; 3.使用software用户登录 co

oracle学习笔记之用户管理-1

sys    system(管理员) scott(普通用户) sqlserver sa 前提:oracle 上,假如自己是管理员,当需要建立用户的时候,由自己操作: 1.创建用户(sys system用户) create user username identified by password; 注意:密码不能以数字开头 create user mmy identified by system; 创建的mmy用户,并不能通过conn立刻登录,需要进行下面一步 2.赋予用户相应的权限 grant

Oracle笔记(十四) 用户管理

Oracle笔记(十四) 用户管理 SQL语句分为三类:DML.DDL.DCL,之前已经讲解完了DML和DDL,现在就差DCL操作的,DCL主要表示的是数据库的控制语句,控制的就是操作权限,而在DCL之中,主要有两个语法:GRANT.REVOKE: 权限的操作基础是需要有用户的,而这个时候就需要通过一个新的用户进行演示,而要想创建新用户则首先必须是具备管理员权限的sys.system两个用户操作. 范例:创建一个dog用户,密码为wangwang CONN sys/change_on_insta

Oracle 表空间管理

Oracle磁盘管理中的最高逻辑层是表空间,Oracle11g中必须创建的4个表空间是SYSTEM,SYSAUX, TEMP, UNDOTBS1. 2 SYSTEM:存储数据字典等,pl/sql代码等. 2 SYSAUX:存储与数据库选项相关的数据 2 TEMP:用于大的排序操作 2 UNDUTBS1:为读一致性和恢复的目的,存储事务信息. 表空间的下一层是段,一个段只能驻留在一个表空间中:一个或多个区可以组成一个段,每个区只能驻留在一个数据文件中:一组连续的数据块可以组成一个区.如果要查询表空