powerdesigner生成mysql语句_oracle创建表的sql语句

powerdesigner生成mysql语句_oracle创建表的sql语句在实际工作中,一张表,我们可能需要在Mysql数据库中建表,又要在Oracle数据库中建表。表中每个字段的数据类型、中文注释、是否可为NULL问题,非常影响我们建表的效率。本篇文章,以Mysql数据库表为原表,通过PowerDesigner工具将其转化成Oracle数据库建表语句。1、以student(学生表)为例,Mysql数据库中建表语句如下所示。需要注意的是,…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

 

      在实际工作中,一张表,我们可能需要在Mysql数据库中建表,又要在Oracle数据库中建表。表中每个字段的数据类型、中文注释、是否可为NULL 问题,非常影响我们建表的效率。本篇文章,以Mysql数据库表为原表,通过PowerDesigner工具将其转化成Oracle数据库建表语句。

 

1、以 student(学生表)为例,Mysql数据库中建表语句如下所示。需要注意的是,若要相对完美的将Mysql数据库表转换成Oracle数据库表,需要严格按照以下Mysql数据库表结构方式,标点符号都不能多、不能少。

 

     1.1、表名、字段名,需要去除 ` 符号  ;

     1.2、若字段定义过程中有 ‘ COLLATE utf8mb4_bin ‘  关键字,去掉 ;

     1.3、若字段定义过程中缺少 ‘NOT NULL’、 ‘DEFAULT NULL’, 请添加 ;

 

-- 去掉的字符:`
-- 去掉的字符:COLLATE utf8mb4_bin 
-- stu_name varchar(255) COLLATE utf8mb4_bin DEFAULT NULL COMMENT '性别',

CREATE TABLE student (
  id int(8) NOT NULL COMMENT '主键',
  stu_name varchar(255) DEFAULT NULL COMMENT '学生姓名',
  stu_sex varchar(8) DEFAULT NULL COMMENT '性别',
  stu_age int(4) DEFAULT NULL COMMENT '学生年龄',
  stu_class varchar(255) DEFAULT NULL COMMENT '学生班级',
  stu_address varchar(255) DEFAULT NULL COMMENT '家庭住址',
  stu_mother varchar(255) DEFAULT NULL COMMENT '学生母亲姓名',
  stu_m_age varchar(255) DEFAULT NULL COMMENT '学生母亲年龄',
  stu_m_phone varchar(255) DEFAULT NULL COMMENT '学生母亲电话',
  stu_father varchar(255) DEFAULT NULL COMMENT '学生父亲姓名',
  stu_f_age varchar(255) DEFAULT NULL COMMENT '学生父亲年龄',
  stu_f_phone varchar(255) DEFAULT NULL COMMENT '学生父亲电话',
  create_date datetime DEFAULT NULL COMMENT '创建日期',
  update_date datetime DEFAULT NULL COMMENT '更新日期',
  start_date datetime DEFAULT NULL COMMENT '入学时间',
  stop_date datetime DEFAULT NULL COMMENT '毕业时间',
  PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='学生表';

 

 

2、 打开 PowerDesigner 软件, 选择 文件 —> 反向工程 —> Database ,如下图1所示。

 

powerdesigner生成mysql语句_oracle创建表的sql语句

                                                                                    图1

 

 

3、 之后,会弹出 New Physical Date Model 窗口。 在该窗口 “常规” 选项界面, 由于我们是将Mysql数据库中表转成Oracle数据库中表,所以 “DBMS” 行选择 “MySQL 5.0” 选项,如图2所示。

 

powerdesigner生成mysql语句_oracle创建表的sql语句

                                                                                    图2

 

 

4、之后,会弹出 “Database Reverse Engineering Options” 窗口, 在该窗口点击 “Add Files (Ctrl + N)” 图标,选择Mysql数据库student表sql脚本,如图3、 图4所示。

 

powerdesigner生成mysql语句_oracle创建表的sql语句

                                                                                    图3

 

powerdesigner生成mysql语句_oracle创建表的sql语句

                                                                                    图4

 

 

5、由步骤4操作后,PowerDesigner 软件界面如下图5所示。

 

powerdesigner生成mysql语句_oracle创建表的sql语句

                                                                                    图5

 

 

6、在 PowerDesigner 软件上,选择 “数据库” —> “Change Current DBMS…” 选项,如下图6所示。 

 

powerdesigner生成mysql语句_oracle创建表的sql语句

                                                                                    图6

 

 

7、之后,会弹出 “Change DBMS” 窗口。 由于我们是将Mysql数据库表转化成Oracle数据库表,在这里 “New 数据库管” 一行选择 “ORACLE Version 11g” 。 “Current 数据库管” 直接手动输入:ORACLE Version 11g  ,如下图7所示。

 

powerdesigner生成mysql语句_oracle创建表的sql语句

                                                                                    图7

 

 

8、使用快捷键: Ctrl + G,调用出 “Database Generation” 窗口,选择生成Oracle建表语句文件的路径,并对文件进行命名,如下图8所示。

 

powerdesigner生成mysql语句_oracle创建表的sql语句

                                                                                    图8

 

 

9、之后,会弹出 “Generated Files” 窗口,由log日志、生成的sql脚本文件可知,程序运行成功。点击 “Generated Files” 窗口中的 “关闭(C)” 按钮后,会弹出 “结果列表” 窗口,该窗口无实际意义,直接关闭。 如下图9、图10所示。

 

powerdesigner生成mysql语句_oracle创建表的sql语句

                                                                                    图9

 

powerdesigner生成mysql语句_oracle创建表的sql语句

                                                                                    图10

 

 

10、打开生成好的SQL脚本,删除语句: constraint PK_STUDENT primary key (id) , 并删除一个多余的逗号。如下图11所示。  

 

powerdesigner生成mysql语句_oracle创建表的sql语句

                                                                                    图11

 

 

11、将SQL脚本中所有的英文半角双引号去掉,可使用NotePad++工具直接替换。如下图12所示,在下图12中,我将转成Oracle建表语句的 student 表名改成了 student003. 因为在我的Oracle数据库中,已经存在了 student 表,这次为了测试检验,故在此将表名更换。

 

powerdesigner生成mysql语句_oracle创建表的sql语句

                                                                                    图12

 

 

12、在SQL语句中,添加给表建立中文注释的命令、添加给表建立主键的命令。命令如下所示,截图如图13所示。


-- 新增命令,给表命名。
COMMENT ON TABLE student IS '学生表';

-- 新增命令,给表添加主键。
alter table student add constraint pk_student primary key(id);

 

powerdesigner生成mysql语句_oracle创建表的sql语句

                                                                                    图13

 

 

13、经过上述处理之后,SQL脚本即可放到PL/SQL软件中直接运行使用。 图14、 图15、 图16 是效果展示图。

Mysql数据库表转成Oracle数据库表的SQL语句如下所示:

/*==============================================================*/
/* DBMS name:      ORACLE Version 11g                           */
/* Created on:     2020/2/14 22:29:28                           */
/*==============================================================*/


drop table student003 cascade constraints;

/*==============================================================*/
/* Table: student003                                             */
/*==============================================================*/
create table student003 
(
   id                 INTEGER              not null,
   stu_name           VARCHAR2(255)        default NULL,
   stu_sex            VARCHAR2(8)          default NULL,
   stu_age            INTEGER              default NULL,
   stu_class          VARCHAR2(255)        default NULL,
   stu_address        VARCHAR2(255)        default NULL,
   stu_mother         VARCHAR2(255)        default NULL,
   stu_m_age          VARCHAR2(255)        default NULL,
   stu_m_phone        VARCHAR2(255)        default NULL,
   stu_father         VARCHAR2(255)        default NULL,
   stu_f_age          VARCHAR2(255)        default NULL,
   stu_f_phone        VARCHAR2(255)        default NULL,
   create_date        DATE                 default NULL,
   update_date        DATE                 default NULL,
   start_date         DATE                 default NULL,
   stop_date          DATE                 default NULL
);

-- 新增命令,给表命名。
COMMENT ON TABLE student003 IS '学生表';

-- 新增命令,给表添加主键。
alter table student003 add constraint pk_student003 primary key(id);


comment on column student003.id is
'主键';

comment on column student003.stu_name is
'学生姓名';

comment on column student003.stu_sex is
'性别';

comment on column student003.stu_age is
'学生年龄';

comment on column student003.stu_class is
'学生班级';

comment on column student003.stu_address is
'家庭住址';

comment on column student003.stu_mother is
'学生母亲姓名';

comment on column student003.stu_m_age is
'学生母亲年龄';

comment on column student003.stu_m_phone is
'学生母亲电话';

comment on column student003.stu_father is
'学生父亲姓名';

comment on column student003.stu_f_age is
'学生父亲年龄';

comment on column student003.stu_f_phone is
'学生父亲电话';

comment on column student003.create_date is
'创建日期';

comment on column student003.update_date is
'更新日期';

comment on column student003.start_date is
'入学时间';

comment on column student003.stop_date is
'毕业时间';

 

powerdesigner生成mysql语句_oracle创建表的sql语句

                                                                                    图14

 

powerdesigner生成mysql语句_oracle创建表的sql语句

                                                                                    图15

 

powerdesigner生成mysql语句_oracle创建表的sql语句

                                                                                    图16

 

姊妹篇文章: PowerDesigner,如何将Oracle数据库建表语句转化成Mysql数据库建表语句。     

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/196116.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • java 程序中的指令重排是什么_指令和程序的区别和联系

    java 程序中的指令重排是什么_指令和程序的区别和联系Java中有两个编译期:1、编译期:调用javac命令将Java代码编译成Java字节码;2、运行期:JIT编译器将字节码编译成机器码。指令重排指令重排是指在程序执行过程中,为了性能考虑,编译器和CPU可能会对指令重新排序。…

    2022年10月17日
  • Linux的文件系统类型「建议收藏」

    Linux的文件系统类型「建议收藏」提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档文章目录前言 一、文件系统类型 二、Linux基本文件操作 1.基本目录和文本命令 三、Linux查找 总结前言本节学习Linux下的l文件系统类型提示:以下是本篇文章正文内容,下面案例可供参考一、文件系统类型不同文件系统采用不同的方法来管理磁盘空间,各有优劣;文件系统是具体到分区的,所以格式化针对的是分区,分区格式化是指采用指定的文件系统类型对分区空间进行登记、索引并建立相应的管理表格的过程。

  • aop 实现原理_简述aop的原理

    aop 实现原理_简述aop的原理概述:最近在开发中遇到了一个刚好可以用AOP实现的例子,就顺便研究了AOP的实现原理,把学习到的东西进行一个总结。文章中用到的编程语言为kotlin,需要的可以在IDEA中直接转为java。这篇文章将会按照如下目录展开:AOP简介 代码中实现举例 AOP实现原理 部分源码解析1.AOP简介相信大家或多或少的了解过AOP,都知道它是面向切面编程,在网上搜索可以找到很多的解释。…

  • 技术解析:阿里云 AnalyticDB 如何实现全球性能第一

    技术解析:阿里云 AnalyticDB 如何实现全球性能第一简介: 北京时间2020年5月4日,TPC官网正式公布,阿里云自研云原生数据仓库AnalyticDB通过严苛的TPC-DS全流程测试,性能较前世界纪录提升29%,单位成本仅为其1/3,再次成为全球性能领先的数据仓库。本文将对AnalyticDB进行全面解析,详细阐述其技术架构及存储和查询技术,并对AnalyticDB的下一步发展做出展望。前言随着云时代全面到来,企业数据需求不断变化,从传统的BigData逐渐向FastData演进,主要表现在如下

  • Ext中apply及applyIf方法的应用

    Ext中apply及applyIf方法的应用Ext中apply及applyIf方法的应用        apply及applyIf方法都是用于实现把一个对象中的属性应用于另外一个对象中,相当于属性拷贝。不同的是apply将会覆盖目标对象中的属性,而applyIf只拷贝目标对象中没有而源对象中有的属性。apply方法的签名为“apply(Objectobj,Objectconfig,Ob

  • webstorm激活码2021【2021.8最新】

    (webstorm激活码2021)这是一篇idea技术相关文章,由全栈君为大家提供,主要知识点是关于2021JetBrains全家桶永久激活码的内容IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.cn/100143.htmlS32PGH0SQB-eyJsa…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号