首發微信公眾號:SQL資料庫運維 原文鏈接:https://mp.weixin.qq.com/s?__biz=MzI1NTQyNzg3MQ==&mid=2247485212&idx=1&sn=450e9e94fa709b5eeff0de371c62072b&chksm=ea37536cdd40da7 ...
首發微信公眾號:SQL資料庫運維
Oracle表是Oracle資料庫的核心,是存儲數據的邏輯基礎。Oracle表是一個二維的數據結構,由列欄位和對應列的數據構成一個數據存儲的結構。可以簡單看成行和列的二維表,列代表著Oracle欄位(column),行代表著一行數據(即一條數據記錄)。
但是在建立Oracle數據表之前,我們需要先瞭解下Oracle欄位數據類型,根據列欄位不同的屬性,使用不同的數據類型進行Oracle表的建立,常用的Oracle列欄位的數據類型如下:
方法一:CREATE TABLE 語法
CREATE TABLE schema_name.table_name ( column_1 data_type column_constraint, column_2 data_type column_constraint, ... table_constraint );
首先,在CREATE TABLE子句中,指定新表所屬的表名和模式名稱。
其次,在圓括弧內列出所有列。如果一個表有多個列,則需要用逗號分隔每個列的定義。列定義包括列名,後跟它的數據類型,例如NUMBER,VARCHAR2和列約束,如NOT NULL,主鍵,約束檢查等。
註意:請註意用戶許可權問題,必須具有CREATE TABLE系統特權才能在模式中創建新表,並使用CREATE ANY TABLE系統特權在其他用戶的模式中創建新表。除此之外,新表的所有者必須具有包含新表或UNLIMITED TABLESPACE系統特權的表空間的配額。許可權授權可參考:Oracle用戶創建、賦權、查詢及刪除操作(點擊可跳轉至文章查看)
在我們之前創建的JT_CS用戶下創建表,一定要有CREATE TABLE許可權,不然無法創建數據表。
創建stuinfo(學生信息表)
1 --實例建表stuinfo 2 create table JT_CS.stuinfo 3 ( 4 stuid varchar2(11) not null,--學號:'S'+班號(7位數)+學生序號(3位數)(不能為空)SC200101001 5 stuname varchar2(50) not null,--學生姓名(不能為空) 6 sex char(1) not null,--性別(不能為空)1(男)、2(女) 7 age number(2) not null,--年齡(不能為空) 8 classno varchar2(7) not null,--班號:'C'+年級(4位數)+班級序號(2位數)(不能為空)C200101 9 stuaddress varchar2(100) default '地址未錄入',--地址 (不填或為空時預設填入‘地址未錄入‘) 10 grade char(4) not null,--年級(不能為空) 11 enroldate date,--入學時間 12 idnumber varchar2(18) default '身份證未採集' not null--身份證(不能為空) 13 ) 14 15 --stuinfo存儲的表空間是users,storage表示存儲參數:區段(extent)一次擴展64k,最小區段數為1,最大的區段數不限制。 16 tablespace USERS 17 storage 18 ( 19 initial 64K 20 minextents 1 21 maxextents unlimited 22 ); 23 24 -- Add comments to the table 25 --comment on table 是給表名進行註釋 26 comment on table JT_CS.stuinfo 27 is '學生信息表'; 28 -- Add comments to the columns 29 --comment on column 是給表欄位進行註釋。 30 comment on column JT_CS.stuinfo.stuid 31 is '學號'; 32 comment on column JT_CS.stuinfo.stuname 33 is '學生姓名'; 34 comment on column JT_CS.stuinfo.sex 35 is '學生性別'; 36 comment on column JT_CS.stuinfo.age 37 is '學生年齡'; 38 comment on column JT_CS.stuinfo.classno 39 is '學生班級號'; 40 comment on column JT_CS.stuinfo.stuaddress 41 is '學生住址'; 42 comment on column JT_CS.stuinfo.grade 43 is '年級'; 44 comment on column JT_CS.stuinfo.enroldate 45 is '入學時間'; 46 comment on column JT_CS.stuinfo.idnumber 47 is '身份證號';
通過上面Crate Table命令創建了stuinfo學生信息表後,還可以繼續給表添加相應的約束來保證表數據的準確性。比如:學生的年齡不能存在大齡的歲數,可能是錯誤數據、性別不能填入不是1(男)、2(女)之外的數據等。
添加stuinfo(學生信息表)約束
--添加約束 --把stuid當做主鍵,主鍵欄位的數據必須是唯一性的(學號是唯一的) alter table JT_CS.STUINFO add constraint pk_stuinfo_stuid primary key (STUID); -- --給欄位年齡age添加約束,學生的年齡只能0-60歲之內的 alter table JT_CS.STUINFO add constraint ch_stuinfo_age check (age>0 and age<=60); --性別不能填入不是1(男)、2(女)之外的數據 alter table JT_CS.STUINFO add constraint ch_stuinfo_sex check (sex='1' or sex='2'); --年級 alter table JT_CS.STUINFO add constraint ch_stuinfo_GRADE check (grade>='2000' and grade<='9999');
方法二:CREATE TABLE AS 語法
除了上邊Create Table 語句可以創建數據表以外,使用Create Table AS語句一樣可以通過複製現有表的列從現有表來創建新表。同時,Create Table 表名 as select 語句也可以實現對select查詢的結果進行快速備份。
--語法:SELECT語句可指定列或添加where條件 CREATE TABLE new_table AS (SELECT * FROM old_table);
CREATE TABLE JT_CS.STUINFO_01 AS (SELECT * FROM JT_CS.STUINFO);
關註“SQL資料庫運維”,後臺或瀏覽至公眾號文章底部點擊“發消息”回覆關鍵字:進群,帶你進入高手如雲的技術交流群。後臺回覆關鍵字:SQL,獲取學習資料。