Oracle 數據類型
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;
Oracle 數據類型