在我们选择工具的时候,往往会优先选择那些免费又好用的工具!Navicat作为一款付费软件,虽然功能强大,但也阻止不了我们探索新工具的步伐。最近体验了一把MySQL的官方客户端工具MySQL Workbench,本文将对其和Navicat做个对比,看看它能否取代Navicat!
安装
我们先把MySQL Workbench安装好,其中有个小坑需要注意下。
- 首先我们需要下载MySQL Workbench的安装包,下载地址:https://dev.mysql.com/downloads/workbench/
![723e7ed3fcde3293255e06a91a1b1134.png](https://i-blog.csdnimg.cn/blog_migrate/e2ff748b186b359dec8059fec3d99116.jpeg)
- 下载完成后我们双击安装会遇到一个问题,MySQL Workbench 8.0版本安装需要先安装Visual C++ 2019 Redistributable Package依赖;
![ba3e6b2d159b953d7d368f76346e1589.png](https://i-blog.csdnimg.cn/blog_migrate/a77953f3a98e4265eec80bbff70119b6.jpeg)
- 下载Visual C++ 2019 Redistributable Package,下载地址:https://support.microsoft.com/en-us/help/2977003/the-latest-supported-visual-c-downloads
![8bc2b3a5e713c70de80a5205f653dcad.png](https://i-blog.csdnimg.cn/blog_migrate/3cc91cafd743bc0c5248fab5cdcfdc99.jpeg)
- 下载完成后安装Visual C++ 2019 Redistributable Package,一直点击下一步即可;
![0ac25f67b22956994469c5b969c851be.png](https://i-blog.csdnimg.cn/blog_migrate/44e5dabf875839118653d90cfc3b28d6.jpeg)
- 之后重新双击MySQL Workbench的安装包,一路点击下一步即可顺利安装了。
![77d14fcc6eb3546377248447d7622fde.png](https://i-blog.csdnimg.cn/blog_migrate/fce163b9d6ebe10b5281d1afc35e3867.jpeg)
使用
接下来我们将通过基础的数据库管理功能,来体验下MySQL Workbench的使用。
建立新连接
双击打开MySQL Workbench,然后输入数据库连接信息即可建立新连接。
![45ee24cae7effd0869ad1997f9acd6ef.png](https://i-blog.csdnimg.cn/blog_migrate/d650fd9edfa1244b16741c0108e0d58c.jpeg)
外观设置
由于默认的编辑器字体比较小,可以改大一些,通过Edit->Preferences选项来修改,不过这里只能通过输入字体名称和大小来改变,有点不太方便!
![a318ef1bb61096ef6006c6247819030d.png](https://i-blog.csdnimg.cn/blog_migrate/02d68d24b549e4e2d0d47f6e4a17ed07.jpeg)
表管理
- 查看数据库表结构,通过右击表选择Table Inspector来查看;
![882c3ce519f3463705dc8ec072b3ef80.png](https://i-blog.csdnimg.cn/blog_migrate/799c5b077169c455ca3e24a54fcaaec2.jpeg)
- 修改数据库表结构,通过右击表选择Alter Table来修改。
![751c3e7951ea8e0ad963ccb810f83977.png](https://i-blog.csdnimg.cn/blog_migrate/cb851c4c2b982c943db2559014047039.jpeg)
数据管理
- 查看表数据,通过右击表选择Select Rows来查看,我们可以发现在SQL编辑器中自动生成了SELECT语句;
![17134db4a235e81f0c9e98ed6b9fa1bd.png](https://i-blog.csdnimg.cn/blog_migrate/b0afb539261f8a121ec09d908e1ed380.jpeg)
- 修改表数据,我们需要双击需要修改的表字段,然后点击Apply来应用;
![676bcfd41eb6217723d8288c879c4971.png](https://i-blog.csdnimg.cn/blog_migrate/8dbed47e10286037e061ba393b60120a.jpeg)
- 我们可以发现最后工具中的修改被转化为了UPDATE语句,可见MySQL Workbench中的数据操作最终会转化为语句来执行。
![985c1c8c542fe79e934ce0f3b3ce852f.png](https://i-blog.csdnimg.cn/blog_migrate/f686f11c28d1f2fcda838c0bb71067ac.jpeg)
SQL操作
- 我们可以使用SQL编辑器来执行SQL语句,使用左上角的按钮可以创建一个SQL编辑器;
![2d0ff7ceea3c7a31bb8cdd144c66bb69.png](https://i-blog.csdnimg.cn/blog_migrate/1659f40e7e0e29bc18aabc4141dcbf86.jpeg)
- MySQL Workbench的SQL提示还是挺全的,来写个SQL试试,基本能够满足平时编辑SQL的需求。
![c54025ae4561edbcd60ee347ddc8382c.gif](https://i-blog.csdnimg.cn/blog_migrate/31c0fc917972bee2b0bebb0975327b68.gif)
实例管理
- 查看MySQL服务状态信息;
![7f6f728e00998fa9796d7c6974a656fa.png](https://i-blog.csdnimg.cn/blog_migrate/9bb0639cd627dfa7290020b3bc201889.jpeg)
- 管理MySQL用户和权限;
![162c0d6b1e7b37e67bddfa72203a3098.png](https://i-blog.csdnimg.cn/blog_migrate/2ce8175d8aaf0e02b84768252228b33d.jpeg)
- 管理MySQL实例,实现启动和关闭;
![93c662d5be053859a2435d45102d85cf.png](https://i-blog.csdnimg.cn/blog_migrate/3b1991f5c5233aed5d75a13fe2930a84.jpeg)
- 查看展示MySQL服务性能信息的仪表盘。
![ff80d43e20614eafbe29a3c7b14a593e.png](https://i-blog.csdnimg.cn/blog_migrate/1cfb7068527c87d0db3c77186b880726.jpeg)
对比Navicat
- Navicat中有个非常好用的数据库设计功能,为此我抛弃了笨重的PowerDesigner,很显然MySQL Workbench并不支持该功能。
![5faed9c51568ef6691c5376fddb474d1.png](https://i-blog.csdnimg.cn/blog_migrate/e2df916f8952e110c1200338089ebd8f.jpeg)
- 使用Navicat设计数据库,具体可以参考《我用起来顺手的数据库设计工具,这次推荐给大家!》。
- Navicat具有强大的数据备份和结构同步功能,平时用来数据备份,同步测试环境的数据库结构到生产环境很好用,如果使用MySQL Workbench估计就只能将SQL进行导入导出了。
![d0fcd9b014fa9b835e7e3bca6355e2e6.png](https://i-blog.csdnimg.cn/blog_migrate/4ae5bca8b4d4750e123217ec97b93e71.jpeg)
- 使用Navicat实现数据备份和结构同步,具体可以参考《Navicat实用功能:数据备份与结构同步》。
- MySQL Workbench中特有的实例管理功能是Navicat所不具备的。
- Navicat能支持MySQL、MariaDB、MongoDB、SQL Server、Oracle、PostgreSQL等多种数据库,很显然MySQL Workbench只能支持MySQL。
总结
总的来说,MySQL Workbench作为一款MySQL数据库管理工具显然足够了,但是Navicat的很多功能它是无法取代的。如果你想设计数据库,拥有更好的数据库运维功能,或者你需要使用多种不同的数据库,那还是使用Navicat吧!