1.知識點:可以對照下面的錄屏進行閱讀
SQL> --創建表 SQL> create table test1 2 (tid number, 3 tname varchar2(20), 4 hidatedate date default sysdate); SQL> --使用as和子查詢快速建表 SQL> --創建表:包含員工號 姓名 月薪 年薪 部門名稱 SQL> create table empincome 2 as 3 select empno,ename,sal,sal*12 annlsal,dname 4 from emp e, dept d 5 where e.deptno=d.deptno; SQL> --rowid 行地址,偽列 SQL> select rowid,empno,ename from emp; SQL> --修改表: 追加新列 修改列 刪除列 重命名列 SQL> --追加新列 SQL> alter table test1 add photo blob; SQL> --修改列 SQL> alter table test1 modify tname varchar2(40); SQL> --刪除列 SQL> alter table test1 drop column photo; SQL> --重命名列 SQL> alter table test1 rename column tname to username; SQL> --刪除表 SQL> drop table TESTDELETE; SQL> --Oracle的回收站 SQL> --查看回收站 SQL> show recyclebin SQL> --清空回收站 SQL> purge recyclebin; SQL> --徹底刪除表 SQL> drop table test1 purge; SQL> -- check約束 SQL> create table test2 2 (tid number, 3 tname varchar2(20), 4 gender varchar2(4) check (gender in ('男','女')), 5 sal number check (sal >0 ) 6 ); SQL> --測試check約束(性別使用特殊值) SQL> insert into test2 values(1,'Tom','啊',1000); SQL> -- 所有約束,約束別名 SQL>create table myperson( 2 pid varchar2(18) constraint myperson_PK primary key, 3 pname varchar2(4) constraint myperson_Name not null, 4 gender varchar2(4) constraint myperson_Gender check (gender in ('男','女')), 5 email varchar2(30) constraint myperson_Email UNIQUE, 6 deptno number constraint myperson_FK references dept(deptno) ON DELETE CASCADE 7 )2.在Sqlplus下實際執行的結果錄屏
SQL> --創建表 SQL> create table test1 2 (tid number, 3 tname varchar2(20), 4 hidatedate date default sysdate); 表已創建。 SQL> insert into test1(tid,tname) values(1,'Tom'); 已創建 1 行。 SQL> select * from test1; TID TNAME HIDATEDATE ---------- -------------------- -------------- 1 Tom 23-10月-12 已選擇 1 行。 SQL> create table emp10 as select * from emp where deptno=10; 表已創建。 SQL> select * from emp10; EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- ---------- --------- ---------- -------------- ----- ---------- ------ 7782 CLARK MANAGER 7839 09-6月 -81 2450 10 7839 KING PRESIDENT 17-11月-81 5000 10 7934 MILLER CLERK 7782 23-1月 -82 1300 10 已選擇3行。 SQL> --快速建表 SQL> --創建表:包含員工號 姓名 月薪 年薪 部門名稱 SQL> create table empincome 2 as 3 select empno,ename,sal,sal*12 annlsal,dname 4 from emp e, dept d 5 where e.deptno=d.deptno; 表已創建。 SQL> select * from empincome; EMPNO ENAME SAL ANNLSAL DNAME ---------- ---------- ----- ---------- -------------- 7369 SMITH 800 9600 RESEARCH 7499 ALLEN 1600 19200 SALES 7521 WARD 1250 15000 SALES 7566 JONES 2975 35700 RESEARCH 7654 MARTIN 1250 15000 SALES 7698 BLAKE 2850 34200 SALES 7782 CLARK 2450 29400 ACCOUNTING 7788 SCOTT 3000 36000 RESEARCH 7839 KING 5000 60000 ACCOUNTING 7844 TURNER 1500 18000 SALES 7876 ADAMS 1100 13200 RESEARCH EMPNO ENAME SAL ANNLSAL DNAME ---------- ---------- ----- ---------- -------------- 7900 JAMES 950 11400 SALES 7902 FORD 3000 36000 RESEARCH 7934 MILLER 1300 15600 ACCOUNTING 已選擇14行。 SQL> host cls SQL> --rowid 行地址 SQL> select rowid,empno,ename from emp; ROWID EMPNO ENAME ------------------ ---------- ---------- AAANnOAAEAAAAAcAAA 7369 SMITH AAANnOAAEAAAAAcAAB 7499 ALLEN AAANnOAAEAAAAAcAAC 7521 WARD AAANnOAAEAAAAAcAAD 7566 JONES AAANnOAAEAAAAAcAAE 7654 MARTIN AAANnOAAEAAAAAcAAF 7698 BLAKE AAANnOAAEAAAAAcAAG 7782 CLARK AAANnOAAEAAAAAcAAH 7788 SCOTT AAANnOAAEAAAAAcAAI 7839 KING AAANnOAAEAAAAAcAAJ 7844 TURNER AAANnOAAEAAAAAcAAK 7876 ADAMS ROWID EMPNO ENAME ------------------ ---------- ---------- AAANnOAAEAAAAAcAAL 7900 JAMES AAANnOAAEAAAAAcAAM 7902 FORD AAANnOAAEAAAAAcAAN 7934 MILLER 已選擇14行。 SQL> host cls SQL> --修改表: 追加新列 修改列 刪除列 重命名列 SQL> desc test1 名稱 是否為空? 類型 ----------------------------------------------------------------------------------- -------- -------------------------------------------------------- TID NUMBER TNAME VARCHAR2(20) HIDATEDATE DATE SQL> alter table test1 add photo blob; 表已更改。 SQL> desc test1 名稱 是否為空? 類型 ----------------------------------------------------------------------------------- -------- -------------------------------------------------------- TID NUMBER TNAME VARCHAR2(20) HIDATEDATE DATE PHOTO BLOB SQL> alter table test1 modify tname varchar2(40); 表已更改。 SQL> desc test1 名稱 是否為空? 類型 ----------------------------------------------------------------------------------- -------- -------------------------------------------------------- TID NUMBER TNAME VARCHAR2(40) HIDATEDATE DATE PHOTO BLOB SQL> alter table test1 drop column photo; 表已更改。 SQL> desc test1 名稱 是否為空? 類型 ----------------------------------------------------------------------------------- -------- -------------------------------------------------------- TID NUMBER TNAME VARCHAR2(40) HIDATEDATE DATE SQL> alter table test1 rename column tname to username; 表已更改。 SQL> desc test1; 名稱 是否為空? 類型 ----------------------------------------------------------------------------------- -------- -------------------------------------------------------- TID NUMBER USERNAME VARCHAR2(40) HIDATEDATE DATE SQL> host cls SQL> --刪除表 SQL> select * from tab; TNAME TABTYPE CLUSTERID ------------------------------ ------- ---------- DEPT TABLE EMP TABLE BONUS TABLE SALGRADE TABLE EMP20 TABLE TESTSAVEPOINT TABLE TESTDELETE TABLE TEST1 TABLE EMP10 TABLE EMPINCOME TABLE 已選擇10行。 SQL> drop table TESTDELETE; 表已刪除。 SQL> --Oracle的回收站 SQL> --查看回收站 SQL> show recyclebin ORIGINAL NAME RECYCLEBIN NAME OBJECT TYPE DROP TIME ---------------- ------------------------------ ------------ ------------------- TESTDELETE BIN$oY28BlKeSle/lJNUpKzrMQ==$0 TABLE 2012-10-23:15:42:09 SQL> --清空回收站 SQL> purge recyclebin 2 ; 回收站已清空。 SQL> --徹底刪除表 SQL> drop table test1 purge; 表已刪除。 SQL> show recyclebin SQL> host cls SQL> -- check約束 SQL> create table test2 2 (tid number, 3 tname varchar2(20), 4 gender varchar2(4) check (gender in ('男','女')), 5 sal number check (sal >0 ) 6 ); 表已創建。 SQL> insert into test2 values(1,'Tom','男',1000); 已創建 1 行。 SQL> insert into test2 values(1,'Tom','啊',1000); insert into test2 values(1,'Tom','啊',1000) * 第 1 行出現錯誤: ORA-02290: 違反檢查約束條件 (SCOTT.SYS_C006031) SQL> create table myperson( 2 pid varchar2(18) constraint myperson_PK primary key, 3 pname varchar2(4) constraint myperson_Name not null, 4 gender varchar2(4) constraint myperson_Gender check (gender in ('男','女')), 5 email varchar2(30) constraint myperson_Email uqiue, 6 deptno number constraint myperson_FK references dept(deptno) ON DELETE CASCADE 7 ); email varchar2(30) constraint myperson_Email uqiue, * 第 5 行出現錯誤: ORA-02253: 此處不允許約束條件說明 SQL> ed 已寫入 file afiedt.buf 1 create table myperson( 2 pid varchar2(18) constraint myperson_PK primary key, 3 pname varchar2(4) constraint myperson_Name not null, 4 gender varchar2(4) constraint myperson_Gender check (gender in ('男','女')), 5 email varchar2(30) constraint myperson_Email UNIQUE, 6 deptno number constraint myperson_FK references dept(deptno) ON DELETE CASCADE 7* ) SQL> / 表已創建。 SQL> insert into myperson values('p001','tom','男','[email protected]',10); 已創建 1 行。 SQL> insert into myperson values('p002','tom','啊','[email protected]',10); insert into myperson values('p002','tom','啊','[email protected]',10) * 第 1 行出現錯誤: ORA-02290: 違反檢查約束條件 (SCOTT.MYPERSON_GENDER) SQL> spool off