Oracle学习(九):创建和管理表

简介: 本文主要讲Oracle创建和管理表

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','男','tom@126.com',10);
已创建 1 行。
SQL> insert into myperson values('p002','tom','啊','tom123@126.com',10);
insert into myperson values('p002','tom','啊','tom123@126.com',10)
*
第 1 行出现错误: 
ORA-02290: 违反检查约束条件 (SCOTT.MYPERSON_GENDER) 
SQL> spool off
相关文章
|
7月前
|
Oracle 安全 关系型数据库
【Oracle】玩转Oracle数据库(六):模式对象管理与安全管理
【Oracle】玩转Oracle数据库(六):模式对象管理与安全管理
86 10
|
7月前
|
SQL Oracle 关系型数据库
【Oracle】玩转Oracle数据库(三):数据库的创建和管理
【Oracle】玩转Oracle数据库(三):数据库的创建和管理
158 5
|
7月前
|
Oracle 关系型数据库 数据库
Oracle查询优化-复制表的定义及数据
【1月更文挑战第5天】【1月更文挑战第14篇】在Oracle数据库中,复制表定义和复制表数据是两个常见的操作。
112 1
|
2月前
|
Oracle 关系型数据库 网络安全
Oracle 19c 安装教程学习
Oracle 19c 安装教程学习
61 2
|
7月前
|
消息中间件 关系型数据库 Kafka
实时计算 Flink版产品使用合集之oracle cdc 抽取新增一张表 可以从savepoint恢复吗
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
6月前
|
SQL Oracle 关系型数据库
实时计算 Flink版产品使用问题之oracle无主键的表支持同步吗如何实现
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
6月前
|
运维 DataWorks Oracle
DataWorks产品使用合集之在标准模式下,当同步Oracle的表或视图时,是否需要在源端的测试和生产环境中都存在要同步的表或视图
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
47 3
|
7月前
|
资源调度 Oracle 关系型数据库
实时计算 Flink版产品使用合集之同步Oracle数据时,一张表产生了大量的连接数,如何处理
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
7月前
|
存储 Oracle 关系型数据库
实验三 Oracle数据库的创建和管理
实验三 Oracle数据库的创建和管理
76 1
|
7月前
|
Oracle 关系型数据库
Oracle 管理诊断数据工具ADRCI
Oracle 管理诊断数据工具ADRCI
74 2

推荐镜像

更多