1. 程式人生 > >Oracle 數據類型

Oracle 數據類型

poi sele 大對象 例如 imageview 撤銷 ima 2gb 外鍵約束

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