当前位置:  数据库>oracle

Oracle 构造与已知表结构相同的表问题

    来源: 互联网  发布时间:2017-04-02

    本文导语: //构造一个与已知表就够相同的表,我们常用的方法为:   //create table t_name as   //select col_name from t_exists   //where 1=0;   //这种构造方法,减少了我们的工作量,带了很大的方便;   //但是你知道吗?这种构造表的方法,仅仅...

//构造一个与已知表就够相同的表,我们常用的方法为:  
//create table t_name as  
//select col_name from t_exists  
//where 1=0;  
//这种构造方法,减少了我们的工作量,带了很大的方便;  
//但是你知道吗?这种构造表的方法,仅仅是构造表的结构与  
//已知表结构相同,其他的关于表、列的约束,列的默认值,注释  
//等这些都没有复制过来。  
create table student(  
       stu_no number(5),  
       stu_name varchar2(20),  
       sex char(1),  
       age number(3))  
--  
alter table student  
add constraint pk_stu primary key(stu_no);  
alter table student  
modify sex default 'M' 
add constraint ck_sex check(sex in('F','M'));  
comment on table student is '学生信息表';  
comment on column student.stu_no is '学生学号';  
comment on column student.stu_name is '学生姓名';  
comment on column student.sex is '性别';  
comment on column student.age is '学生年龄';  
--  
SQL> desc student;  
Name     Type         Nullable Default Comments   
-------- ------------ -------- ------- --------   
STU_NO   NUMBER(5)                     学生学号   
STU_NAME VARCHAR2(20) Y                学生姓名   
SEX      CHAR(1)      Y        'M'     性别       
AGE      NUMBER(3)    Y                学生年龄   
--   
create table t_stu as 
select * from student  
where 1=0;  
--  
SQL> desc t_stu;  
Name     Type         Nullable Default Comments   
-------- ------------ -------- ------- --------   
STU_NO   NUMBER(5)    Y                           
STU_NAME VARCHAR2(20) Y                           
SEX      CHAR(1)      Y                           
AGE      NUMBER(3)    Y  
//从表结构,我们看到了,t_stu表只是复制了student表的结构,  
//而我们刚刚才为student表添加的primary key,default,comment,  
//全部都没有复制过来。  
//如果你不仅想要构造表结构,而且还要向表中添加现存表中的数据,  
//你可以这样写:  
create table t_emp as 
select * from scott.emp  
order by sal  
where 1=1;//这个条件可有可无  
//实例:  
SQL> create table t_emp as 
  2  select * from scott.emp  
  3  where rownum select rownum,t.* from t_emp t;  
    ROWNUM EMPNO ENAME      JOB         MGR HIREDATE          SAL      COMM DEPTNO  
---------- ----- ---------- --------- ----- ----------- --------- --------- ------  
         1  7369 SMITH      CLERK      7902 1980-12-17     800.00               20  
         2  7521 WARD       SALESMAN   7698 1981-2-22     1250.00    500.00     30  
         3  7654 MARTIN     SALESMAN   7698 1981-9-28     1250.00   1400.00     30  
         4  7499 ALLEN      SALESMAN   7698 1981-2-20     1600.00    300.00     30  
         5  7566 JONES      MANAGER    7839 1981-4-2      2975.00               20 


































































    
 
 

您可能感兴趣的文章:

 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle物理结构概述
  • 轻松理解Oracle数据库中的物理结构
  • ORACLE 修改表结构 之ALTER CONSTAINTS的使用
  • 简述Oracle数据仓库的体系结构
  • oracle复制表结构和复制表数据语句分享
  • 手把手教你Oracle数据库导出数据库结构到PowerDesigner
  • oracle 数据库学习 基本结构介绍
  • Oracle体系结构需要首先了解的两个概念
  • Oracle网络应用结构
  • Oracle两个基本概念帮你了解体系结构
  • Oracle专用服务器的内存结构分布原则
  • 在Oracle网络结构解决连接问题
  • HTML教程 iis7站长之家
  • Oracle 11g Release (11.1) 索引底层的数据结构
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle 数据库开发工具 Oracle SQL Developer
  • Oracle 10g和Oracle 11g网格技术介绍
  • Oracle EBS R12 支持 Oracle Database 11g
  • oracle中如何把表中具有相同值列的多行数据合并成一行
  • SCO unix下安装oracle,但没有光盘,请大家推荐一个oracle下载站点(unix版本的)。谢谢!!!!
  • Oracle 数据库(oracle Database)性能调优技术详解
  • 请问大家用oracle数据库, 用import oracle.*;下的东西么? 还是用标准库?
  • ORACLE日期相关操作
  • Linux /$ORACLE_HOME $ORACLE_HOME


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3