MySQL Workbench的使用教程

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:
MySQL Workbench是一款专为MySQL设计的ER/数据库建模工具。它是著名的数据库设计工具DBDesigner4的继任者。
MySQL Workbench 是 MySQL AB 最近释放的可视数据库设计工具。这个工具是设计 MySQL 数据库的专用工具。
MySQL Workbench 拥有很多的功能和特性;这篇由Djoni Darmawikarta 写的文章通过一个示例展现了其中的一些。我们将针对一个订单系统建立一个物理数据模型,这里的订单系统可以是销售单也可以是订单,并且使用  forward-engineer(正向引擎) 将我们的模型生成为一个 MySQL 数据库。http://dev.mysql.com/doc/workbench/en/index.html
MySQL Workbench 是 MySQL 最近释放的可视数据库设计工具。这个工具是设计 MySQL 数据库的专用工具。
你在 MySQL Workbench 中建立的被称之为物理数据模型。一个物理数据模型是针对一个特定 RDBMS 产品的数据模型;本文中的模型将具有一些 MySQL 的独特规范。我们可以使用它生成(forward-engineer)数据库对象,除了包含表和列(字段)外,也可以包含视图。
MySQL Workbench 拥有很多的功能和特性;这篇由 Djoni Darmawikarta写的文章通过一个示例展现了其中的一些。我们将针对一个订单系统建立一个物理数据模型,这里的订单系统可以是销售单也可以是订单,并且使用  forward-engineer(正向引擎) 将我们的模型生成为一个 MySQL 数据库。 
我们的示例中使用 MySQL Workbench 创建的物理模型看上去就像下图这样: 

创建订单方案(ORDER Schema)
首先让我们来创建一个保存订单物理模型的方案。点击 + 按钮(红色标注的地方)

更改新的方案默认名称为订单。注意,当你键入方案名时,在 Physical Schemata 上的标签名也会随之改变——这是一个很好的特性。
 
 
订单方案被增加到目录(Catalog)中 (图中红色圈住的部分)。 

  重命名方案后关闭 schema 窗口。 

创建订单表
我们现在创建订单模型中的三个表:ORDER 表以及它的两个子表 SALES_ORDER 和PURCHASE_ORDER。首先,确信你已经选择了 ORDER 方案的标签,这样,我们创建的表才会包含于这个方案。
 
我们将要创建的表是作为 EER 图表展示的(EER = Enhanced Entity Relationship)。所以,双击 Add Diagram 按钮。 

  单击 Table 图标,然后移动鼠标到 EER Diagram 区域,在你想放置第一个表的位置上单击鼠标。 

 

  对于其他两个表,重复上面的操作。你可以通过拖拽来移动表的位置。 

   下一步,我们要对 table1 做一些操作,这些操作是通过 Workbench 的表编辑器完成的。要打开表编辑器,只需右键选择 table1 并选择 Edit Table 菜单。 

键入 table1 的表名 ORDER 。 

  接下来,增加列(字段)。选择 Columns 标签。将列名(字段名) idORDER 更改为  ORDER_NO. 

在下拉列表框中选择数据类型 INT 。 

我们希望 ORDER_NO 列的值可以被 MySQL 数据库自动控制,所以,我们选定 AI 列 (Auto Increment——自增量).
 
AI 是 MySQL 数据库的一个特性。 

你也可以指定表的其他物理属性,例如它的 Collation 属性;当然可以指定表的其他高级选项,例如 trigger 和 portioning (分别对应 Trigger 和 Partioning 标签)。 

注意,这时,在 diagram 中我们表 table1 已经改变为 ORDER,并且,它有一个列(字段)ORDER_NO。在目录中,你也可以看到有三个表。
 
在表右侧的黑点,表示它们包含在一个图表中。
 
 
 
如果你展开 ORDER ,你可以看到 ORDER_NO 列。因为我们定义它为主键,所以在它左侧有一个 key 图标。 

  使用同样的方式来创建 SALES_ORDER 表及其中的列(字段)。 

 最后,创建 PURCHASE_ORDER 表及其中的列(字段)。
  
创建关系
我们已经创建了三个表。到这里并没有结束;我们仍旧需要创建它们的关系。
 
SALES_ORDER 是 ORDER 的子表,意味着它们是 1:1 ,SALES_ORDER 为子表, ORDER 为父表,并将 ORDER 的键移动到 SALES_ORDER 。所以,选择(单击)1:1 identifying relationship 图标,然后在 SALES_ORDER 表上单击,再在 ORDER 表上单击。 

  注意,当你在单击表时,图标将变为带有 1:1 关系的手型。 

  1:1 关系就是这样设置的;ORDER_NO 主键被移动到 SALES_ORDER 表并作为它的主键。 

  下一步,创建 PURCHASE_ORDER 到 ORDER 的关系,它仍旧是 1:1 关系。 

  我们现在已经完成了表及表之间关系的设计;将我们的模型保存为 ORDER.mwb. 

 

生成 DDL 和数据库
最终在本文设计数据模型的目的是为了建立 MySQL 数据库。我们将首先生成 DDL(SQL CREATE script),然后执行这个脚本。
 
从 File | Export 菜单中,选择 Forward Engineer SQL CREATE Script. 

 

 

  最后,执行保存的 SQL CREATE 脚本。MySQL Workbench 自身并没有执行这个脚本的能力;我们可以在 MySQL 命令控制台中来执行它。 

 

  你也可以在其中来查看表是否已经被创建。 

 
总结
这篇文章向你展示了在MySQL Workbench 中如何可视的建立 MySQL 物理数据模型,并使用它来创建一个 MySQL 数据库。
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
SQL 存储 关系型数据库
什么是MySQL Workbench
【10月更文挑战第17天】什么是MySQL Workbench
70 0
|
3月前
|
存储 SQL 关系型数据库
使用MySQL Workbench进行数据库备份
【9月更文挑战第13天】以下是使用MySQL Workbench进行数据库备份的步骤:启动软件后,通过“Database”菜单中的“管理连接”选项配置并选择要备份的数据库。随后,选择“数据导出”,确认导出的数据库及格式(推荐SQL格式),设置存储路径,点击“开始导出”。完成后,可在指定路径找到备份文件,建议定期备份并存储于安全位置。
493 11
|
3天前
|
NoSQL Java 关系型数据库
Liunx部署java项目Tomcat、Redis、Mysql教程
本文详细介绍了如何在 Linux 服务器上安装和配置 Tomcat、MySQL 和 Redis,并部署 Java 项目。通过这些步骤,您可以搭建一个高效稳定的 Java 应用运行环境。希望本文能为您在实际操作中提供有价值的参考。
51 26
|
4月前
|
关系型数据库 MySQL Java
centos7安装mysql教程及Navicat平替软件
【8月更文挑战第17天】本教程详述CentOS 7上安装MySQL的过程。首先确保移除任何预装的MySQL组件,然后通过wget获取并安装MySQL的YUM源。可以选择安装特定版本如5.7或8.0。安装MySQL服务器后,启动服务并查找初始密码。登录MySQL后应立即更改密码,并可根据需要设置远程访问权限。此外,还推荐使用免费开源的DBeaver作为数据库管理工具,提供了安装步骤以方便管理和操作MySQL数据库。
161 3
|
13天前
|
关系型数据库 MySQL Java
Servlet+MySQL增删改查 原文出自[易百教程] 转载请保留原文链接: https://www.yiibai.com/geek/1391
对于任何项目开发,创建,读取,更新和删除(CRUD)记录操作是应用程序的一个最重要部分。
54 20
|
2月前
|
存储 SQL 关系型数据库
【入门级教程】MySQL:从零开始的数据库之旅
本教程面向零基础用户,采用通俗易懂的语言和丰富的示例,帮助你快速掌握MySQL的基础知识和操作技巧。内容涵盖SQL语言基础(SELECT、INSERT、UPDATE、DELETE等常用语句)、使用索引提高查询效率、存储过程等。适合学生、开发者及数据库爱好者。
51 0
【入门级教程】MySQL:从零开始的数据库之旅
|
2月前
|
tengine 关系型数据库 MySQL
Tengine、Nginx安装MySQL数据库命令教程
本指南详细介绍了在Linux系统上安装与配置MySQL数据库的步骤。首先通过下载并安装MySQL社区版本,接着启动MySQL服务,使用`systemctl start mysqld.service`命令。若启动失败,可尝试使用`sudo /etc/init.d/mysqld start`。利用`systemctl status mysqld.service`检查MySQL的服务状态,确保其处于运行中。通过日志文件获取初始密码,使用该密码登录数据库,并按要求更改初始密码以增强安全性。随后创建一个名为`tengine`的数据库,最后验证数据库创建是否成功以及完成整个设置流程。
|
2月前
|
存储 SQL 关系型数据库
MySQL Workbench支持哪些数据库引擎
【10月更文挑战第17天】MySQL Workbench支持哪些数据库引擎
43 0
|
4月前
|
SQL 关系型数据库 MySQL
PHP与MySQL交互之基础教程
【8月更文挑战第31天】 在数字世界中,数据是推动一切的核心力量。本文将引导你探索PHP与MySQL的协同工作,通过实际代码示例,展示如何建立连接、执行查询以及处理结果集。无论你是初学者还是希望巩固知识的开发者,这篇文章都将为你提供宝贵的实践知识。
|
4月前
|
关系型数据库 MySQL 网络安全
MySQL主从复制详细教程
配置MySQL的主从复制是一个细致的过程,需要仔细遵循上述步骤进行。一旦配置完成并运行正常,主从复制将大大提高数据库的可用性和读写性能。在操作过程中,务必保持谨慎,确保数据的一致性和安全性。
445 0