MySQL Workbench简易入门文档

前言

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

创建数据库

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

数据库连接

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

MySQL Workbench创建数据库菜单

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

MySQL中的索引和视图

前言

索引是数据库中用来提高性能的最常用工具,所有MySQL的列类型都可以被索引,不同的存储引擎支持的最大索引数和最大索引长度不同,大多数存储引擎至少支持16个索引,总索引藏毒至少为256字节。

MyISAM和InnoDB存储引擎的表默认创建的都是BTREE索引,默认情况下MEMORY存储引擎使用HASH索引,但也支持BTREE索引。

MySQL数据类型和字符集的选择

前言

在使用MySQL的时候我们会遇到一个问题就是如何去选择合适的数据类型和字符集,选择合适的数据类型可以提供效率和节省空间,选择合适的字符集可以解决一些编码问题。

数据类型

char和varchar

都是用来存储字符串的,但是它们的检索方式不同,char属于固定长度的字符类型,而varchar属于可变长度的字符类型。

char(4)存储长度varchar(4)存储长度
‘’‘    ’4个字节‘’1个字节
‘ab’‘ab  ’4个字节‘ab’2个字节
‘abc’‘abc ’4个字节‘abc’3个字节
‘abcd’‘abcd’4个字节‘abcd’4个字节

由于char是固定长度的,所以它的处理速度比varchar快的多,但是浪费存储空间,所以对于那些长度变化不大并对查询速度有要求的数据可以考虑使用char类型来存储。

另外,随着MySQL版本的不断升级,varchar数据类型的性能也在不断改进并提高,所以实际使用中varchar被使用的更多。

MySQL的存储引擎选择

前言

和大多数数据库不同的是MySQL有一个存储引擎的概念,针对不同的存储场景和需求可以选择最优的存储引擎。用户可以根据应用的需要选择如何存储和索引数据、是否使用事务等。

MySQL5.7支持的存储引擎包括MyISAM、InnoDB、BDB、MEMORY、MERGE、EXAMPLE、NDB Cluster、ARCHIVE、CSV、BLACKHOLE、FEDERATED等,其中InnoDB和BDB提供事务安全表,其他存储引擎都是非事务安全表。

默认引擎

在MySQL5.5之前系统默认使用的是MyISAM引擎,在MySQL5.5之后改为了InnoDB, 查看当前默认存储引擎:

1
2
3
4
5
6
7
8
9
10
mysql> show variables like '%storage_engine%';
+----------------------------------+--------+
| Variable_name | Value |
+----------------------------------+--------+
| default_storage_engine | InnoDB |
| default_tmp_storage_engine | InnoDB |
| disabled_storage_engines | |
| internal_tmp_disk_storage_engine | InnoDB |
+----------------------------------+--------+
4 rows in set (0.00 sec)

MySQL中常用函数

前言

这一篇我们来看看MySQL中提供的内建函数,这些函数可以帮助我们编写简单快捷的SQL语句。

字符串函数

函数功能
CONCAT(S1, S2, …Sn)连接S1,S2,…Sn为一个字符串
INSERT(str, x, y, instr)将字符串str从第x位置开始,y个字符长度的子串替换为字符串instr
LOWER(str)将字符串str中所有字符变为小写
UPPER(str)将字符串str中所有字符变为大写
LEFT(str, x)返回字符串str最左边的x个字符
RIGHT(str, x)返回字符串str最右边的x个字符
LPAD(str, n, pad)用字符串pad对str最左边进行填充,直到长度为n个字符长度
RPAD(str, n, pad)用字符串pad对str最右边进行填充,直到长度为n个字符长度
LTRIM(str)去掉字符串str左侧的空格
RTRIM(str)去掉字符串str行尾的空格
REPEAT(str, x)返回str重复x次的结果
REPLACE(str, a, b)用字符串b替换字符串str中所有出现的字符串a
STRCMP(s1, s2)比较字符串s1和s2
TRIM(str)去掉字符串行尾和行头的空格
SUBSTRING(str, x, y)返回从字符串str的x位置起y个字符串长度的子串

MySQL中的运算符

前言

上一篇对MySQL的基础有了一个初步认识,接下来我们看一下MySQL中的运算符,这些运算符可以用来连接表达式,这一篇多为SQL语句。

算数运算符

算数运算符包括加、减、乘、除和模运算。

运算符作用
+加法
-减法
*乘法
/,DIV除法,返回商
%,MOD除法,返回余数
1
2
3
4
5
6
7
mysql> select 0.1+0.3333, 0.1-0.3333, 0.1*0.3333, 1/2, 1%2;
+------------+------------+------------+--------+------+
| 0.1+0.3333 | 0.1-0.3333 | 0.1*0.3333 | 1/2 | 1%2 |
+------------+------------+------------+--------+------+
| 0.4333 | -0.2333 | 0.03333 | 0.5000 | 1 |
+------------+------------+------------+--------+------+
1 row in set (0.01 sec)

值得注意的是如果除数是0则是非法的,返回结果为NULL.

MySQL基础回顾

前言

最近想做一个小项目,具有三端(Android,Web,后端),所以复习一下数据库相关知识,就以这一篇博文为开端复习整理一下数据库相关知识点。本文开始之前我使用的是Mac OS安装的MySQL 5.7版本,你也可以在你的Windows或者Linux系统上安装MySQL社区版,建议使用Linux环境。

好了,我们开始!

1
> mysql -u root -p

数据库基础管理

显示数据库

1
2
3
4
5
6
7
8
9
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| sys |
+--------------------+
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

×