Oracle 数据类型
创建表时,必须为各个列指定数据类型
以下是 Oracle 数据类型的类别:
Oracle主要数据类型
Character 数据类型
Char:固定长度字母数字值,可1-2000个字节
Varchar2:可变长度,1-4000个字节
Long:可变长度,最多2G
Number 数据类型
可以存储整数、浮点数和实数
最高精度为 38 位
格式: NUMBER [( p[, s])]
Date 数据类型
存储日期和时间值
Date:存储日期和时间部分,精确到整个的秒
Timestamp:存储日期、时间和时区信息,秒值精确到小数点后6位
RAW/LONG RAW数据类型
RAW:存储二进制数据,最多2000字节
LONG RAW:用于存储可变长度的二进制数据,最多2GB
LOB数据类型
称为“大对象”数据类型,可以存储多达 4GB 的非结构化信息,例如声音剪辑和视频文件等,允许对数据进行高效、随机、分段的访问
CLOB:字符数据;BLOB:二进制对象,如图形、视频、音频等;BFILE :即 Binary File(二进制文件),它用于将二进制数据存储在数据库外部的操作系统文件中
SQL 语句复习
SQL 支持下列类别的命令:
数据定义语言(DDL):用于改变数据库结构
CREATE ALTER DROP
数据操纵语言(DML):用于检索修改和插入数据
INSERT SELECT DELETE UPDATE
事务控制语言(TCL):保证事务的执行
COMMIT ROLLBACK SAVEPOINT
数据控制语言(DCL):提供权限控制命令
GRANT REVOKE
表管理--创建表
利用现有的表创建表
语法:
CREATE TABLE <new_table_name> AS SELECT column_names FROM <old_table_name>;
示例:
SQL> CREATE TABLE newemp
AS SELECT * FROM emp[WHERE 1 = 2;];
SQL> CREATE TABLE newemp
AS SELECT empno, salary
FROM emp;
表管理--约束
五大约束
1、非空约束:NOT NULL
2、主键约束:PRIMARY KEY,唯一、且非空
3、外键约束:FOREIGN KEY ... REFERENCES
4、唯一约束:UNIQUE,唯一,允许为空
5、条件约束:CHECK
列级约束
约束作为列定义的一部分,允许定义全部的五类约束
SQL> CREATE TABLE clazz_table (
cid NUMBER(10)PRIMARY KEY,
cname VARCHAR2(30) NOT NULL,
cdate DATE);
SQL> CREATE TABLE student_table(
sid NUMBER(10) primary key ,
clazzid NUMBER(10)REFERENCES clazz_table(cid),
sno VARCHAR2(30)UNIQUE,
sname VARCHAR(30) NOT NULL,
sage NUMBER(3) CHECK(sage>0 AND sage<120));
注意:
列名、数据类型、缺省值的次序不能乱;
在列定义的最后,指定列类型的约束;
主键约束的列可以不指定非空约束(NOT NULL)。
表级约束
约束作为表定义的一部分,除非空约束外,允许定义其他四类约束
唯一约束
CONSTRAINT nameUNIQUE(column[,column...])
主键约束
CONSTRAINT name PRIMARY KEY(column[,column...])
外键约束
CONSTRAINT name FOREIGN KEY (column[,column...]) REFERENCES table(column[,column...])
条件约束
CONSTRAINT name CHECK(condition)
定义表级约束
SQL>create table account(
name VARCHER2(32) ,
acc_type NUMBER(1) NOT NULL,
acc_code VARCHAR2(32),
ba NUMBER(5,2) DEFAULT 100,
CONSTRAINT pk_qrsx_account PRIMARY KEY (name),
CONSTRAINT uk_qrsx_account UNIQUE(acc_code),
CONSTRAINT ck_qrsx_account CHECK(ba>=100 AND ba<=1000));
表管理--修改表
ALTER TABLE :修改表
列的添加、修改
给表添加/删除约束
语法:
ALTER TABLE[add][modify][drop column]
示例:
alter table users add(pubdate date);
alter table users add(age number)
alter table users modify(userName varchar2(20));
alter table users drop(password);
alter table users add primary key(userId);
表管理--其它
RENAME table_name TO new_name :重命名
TRUNCATE TABLE:删除表 ,记录不可恢复
DROP TABLE:删除表
COMMENT ON:为表添加注释
示例:
RENAME users to test
DROP TABLE users;--删除表结构
TRUNCATE TABLE users --删除记录,释放空间
DELETE FROM emp --删除记录,但可以恢复
COMMENT ON TABLE emp IS 'Employee Information';
Oracle数据库中的表
用户表
用户创建和维护的一系列表的集合包含用户的信息
数据字典
Oracle 服务器创建和维护的一系列表和视图的集合,包含数据库的信息
user_xxx用户拥有的
all_xx 用户有权查看
dba_xxx(sys) 所有的信息
数据控制语言DCL
数据控制语言为用户提供权限控制命令
用于权限控制的命令有:
GRANT 授予权限
REVOKE 撤销已授予的权限
示例:
SQL> GRANT ALL ON EMP TO TEA;
SQL> REVOKE SELECT, UPDATE ON EMP FROM TEA;