MySQL Workbench简易入门文档

前言

在日常各种工作中,图形化工具为我们提供了很大的便利,MySQL数据库有很多图形化工具,其中MySQL Workbench是MySQL公司开发的集成图形化工具,这个是一个免费的工具可以从MySQL官网下载,里面集成了数据建模、MySQL操作工具箱、数据迁移工具等。

创建数据库

不得不说这个工具的智能和完美,我安装好后打开它已经列出了本地数据库连接列表:

数据库连接

进去之后有一行菜单可以方便我们创建数据库,表,视图等。

MySQL Workbench创建数据库菜单

我们先来创建一个数据库,名字为’mydb’

创建MySQL数据库

设计数据库表

接下来我们使用MySQL WorkBench来数据建模,数据建模工具可以很方便的创建物理模型,然后通过正向工程将物理模型转换为实际的数据库对象,通过这种方式可以很大的提高数据库设计效率。

数据库建模

第一步:在主界面单击Create New EER Model按钮,在弹出的面板中双击Add Diagram打开模型编辑器。

第二步:单击工具栏的创建表图标,然后在编辑区单击创建一张表:

创建表

第三步:双击刚才创建的表,编辑表名和表字段:

修改表名称添加字段

第四步:用类似的方式创建另一张表subject,最后使用n:m连接线建立student和subject的多堆多关系。

建立表的多对多关系

系统自动生成了student_has_subject中间表,包含字段student_stuid和subject_subid,都设置为中间表的外键,引用的表为两表主键。

第五步:点击File—>Export—>Forward Engineer SQL Script 弹出SQL脚本导出选项窗口,选择保存路径,然后按照提示选择对于配置(可以按照默认)。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
-- MySQL Script generated by MySQL Workbench
-- Fri May 3 13:38:04 2019
-- Model: New Model Version: 1.0
-- MySQL Workbench Forward Engineering

SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0;
SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0;
SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';

-- -----------------------------------------------------
-- Schema mydb
-- -----------------------------------------------------

-- -----------------------------------------------------
-- Schema mydb
-- -----------------------------------------------------
CREATE SCHEMA IF NOT EXISTS `mydb` DEFAULT CHARACTER SET utf8 ;
USE `mydb` ;

-- -----------------------------------------------------
-- Table `mydb`.`student`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `mydb`.`student` (
`stuid` INT NOT NULL,
`stdname` VARCHAR(20) NULL,
PRIMARY KEY (`stuid`))
ENGINE = InnoDB;


-- -----------------------------------------------------
-- Table `mydb`.`subject`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `mydb`.`subject` (
`subid` INT NOT NULL,
`subname` VARCHAR(20) NULL,
PRIMARY KEY (`subid`))
ENGINE = InnoDB;


-- -----------------------------------------------------
-- Table `mydb`.`student_has_subject`
-- -----------------------------------------------------
CREATE TABLE IF NOT EXISTS `mydb`.`student_has_subject` (
`student_stuid` INT NOT NULL,
`subject_subid` INT NOT NULL,
PRIMARY KEY (`student_stuid`, `subject_subid`),
INDEX `fk_student_has_subject_subject1_idx` (`subject_subid` ASC) VISIBLE,
INDEX `fk_student_has_subject_student_idx` (`student_stuid` ASC) VISIBLE,
CONSTRAINT `fk_student_has_subject_student`
FOREIGN KEY (`student_stuid`)
REFERENCES `mydb`.`student` (`stuid`)
ON DELETE NO ACTION
ON UPDATE NO ACTION,
CONSTRAINT `fk_student_has_subject_subject1`
FOREIGN KEY (`subject_subid`)
REFERENCES `mydb`.`subject` (`subid`)
ON DELETE NO ACTION
ON UPDATE NO ACTION)
ENGINE = InnoDB;


SET SQL_MODE=@OLD_SQL_MODE;
SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS;
SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS;

SQL脚本创建表

我们使用刚才导出的mydb.sql脚本来自动创建数据库表,File—>Open SQL Script->选择文件。

打开SQL脚本文件

接下来检查一下文件是否有错误,如果有旁边会有错误提示,解决相关错误提示后点击那个”闪电”图标即可自动执行该脚本文件内容。执行完后如果控制台全部是绿色的对勾则表示生成成功,点击左边数据库表上方刷新按钮。

创建成功的数据库表

最后我们打开任意一个数据库表,往里面添加一些测试数据:

添加测试数据

总结

最基本的操作过程就是如此,同样的我们可以去编辑修改数据库表的字段等操作,或者我们可以将我们创建的表导入到数据库模型中编辑继续导出SQL脚本,基本上我们常用的操作都能通过MySQL Workbench实现,它的功能远不止这些,你可以继续探索。

评论

Ajax Android AndroidStudio Animation Anroid Studio AppBarLayout Babel Banner Buffer Bulma ByteBuffer C++ C11 C89 C99 CDN CMYK COM1 COM2 CSS Camera Raw, 直方图 Chrome ContentProvider CoordinatorLayout C语言 DML DOM Dagger Dagger2 Darktable Demo Document DownloadManage ES2015 ESLint Element Error Exception Extensions File FileProvider Flow Fresco GCC Git GitHub GitLab Gradle Groovy HTML5 Handler HandlerThread Hexo Hybrid I/O IDEA IO ImageMagick IntelliJ Intellij Interpolator JCenter JNI JS Java JavaScript JsBridge Kotlin Lab Lambda Lifecycle Lint Linux Looper MQTT MVC MVP Maven MessageQueue Modbus Momentum MySQL NDK NIO NexT Next Nodejs ObjectAnimator Oracle VM Permission PhotoShop Physics Python RGB RS-232 RTU Remote-SSH Retrofit Runnable RxAndroid RxJava SE0 SSH Spring SpringBoot Statubar Task Theme Thread Tkinter UI UIKit UML VM virtualBox VS Code VUE ValueAnimator ViewPropertyAnimator Vue Web Web前端 Workbench api apk bookmark by关键字 compileOnly css c语言 databases demo hexo hotfix html iOS icarus implementation init jQuery javascript launchModel logo merge mvp offset photos pug query rxjava2 scss servlet shell svg tkinter tomcat transition unicode utf-8 vector virtual box vscode 七牛 下载 中介者模式 串口 临潼石榴 主题 书签 事件 享元模式 仓库 代理模式 位运算 依赖注入 修改,tables 光和色 内存 内核 内部分享 函数 函数式编程 分支 分析 创建 删除 动画 单例模式 压缩图片 发布 可空性 合并 同向性 后期 启动模式 命令 命令模式 响应式 响应式编程 图层 图床 图片压缩 图片处理 图片轮播 地球 域名 基础 增加 备忘录模式 外观模式 多线程 大爆炸 天气APP 太白山 头文件 奇点 字符串 字符集 存储引擎 宇宙 宏定义 实践 属性 属性动画 岐山擀面皮 岐山肉臊子 岐山香醋 工具 工厂模式 年终总结 开发技巧 异常 弱引用 恒星 打包 技巧 指针 插件 摄影 操作系统 攻略 故事 数据库 数据类型 数组 文件 新功能 旅行 旋转木马 时序图 时空 时间简史 曲线 杂谈 权限 枚举 架构 查询 标准库 标签选择器 样式 核心 框架 案例 桥接模式 检测工具 模块化 模板引擎 模板方法模式 油泼辣子 泛型 洛川苹果 浅色状态栏 源码 源码分析 瀑布流 热修复 版本 版本控制 状态栏 状态模式 生活 留言板 相册 相对论 眉县猕猴桃 知识点 码云 磁盘 科学 笔记 策略模式 类图 系统,发行版, GNU 索引 组件 组合模式 结构 结构体 编码 网易云信 网格布局 网站广播 网站通知 网络 美化 联合 膨胀的宇宙 自定义 自定义View 自定义插件 蒙版 虚拟 虚拟机 补码 补齐 表单 表达式 装饰模式 西安 观察者模式 规范 视图 视频 解耦器模式 设计 设计原则 设计模式 访问者模式 语法 责任链模式 贪吃蛇 转换 软件工程 软引用 运算符 迭代子模式 适配器模式 选择器 通信 通道 配置 链表 锐化 错误 键盘 闭包 降噪 陕西地方特产 面向对象 项目优化 项目构建 黑洞
Your browser is out-of-date!

Update your browser to view this website correctly. Update my browser now

×