想要Freestyle?先要遵守 MySQL 这十大铁律!

在工作中作为DBA的我们,可能也会需要面对开发人员各种 Freestyle 的要求,但是他们是否知道在操作数据库的时候,需要注意哪些事项呢?

今儿带着大家简单聊聊 MySQL 数据库的开发行为规范,十大铁的纪律。对DBA老铁们是一种帮助,对开发人员也是一种学习。


1. 创建的表要使用 innodb 存储引擎表

现在基本上大部分业务都是 innodb 存储引擎,MySQL 8.0 开始,彻底不再使用 myisam。每张表都要包含一个自增的主键 id。

2. 数据类型的选择上,要秉着越简单越好,越小越好的原则。

建议使用 int 来存储 ipv4 的类型,可以通过函数转换。金钱类的字段也可以存储为 int 类型,用分做单位就可以了。

时间类型可以采用 datetime,它比 tiemstamp 可用范围大,存储空间也从原来的 8 字节,降到了 5 字节,性能上也不错。

mysql> select inet_aton(‘192.168.56.132‘);
+-----------------------------+
| inet_aton(‘192.168.56.132‘) |
+-----------------------------+
|          3232249988 | 
+-----------------------------+

mysql> select inet_ntoa(3232249988);
+-----------------------+
| inet_ntoa(3232249988) |
+-----------------------+
| 192.168.56.132        | 
+-----------------------+
1 row in set (0.00 sec)

3. 库名、表名、字段名必须使用小写字母,采用“_“分割

MySQL 数据库中,通过参数 lower_case_table_names 来区分表名的大小写 默认为 0,代表大小写敏感。如果是 1,大小写不敏感,以小写存储。

4. 不建议使用 ENUM 类型,使用 TINYINT 来代替。

也不建议使用大数据类型的字段如text或者blob出现在业务表中。

5. 表字符集使用 utf8,必要时可申请使用 utf8mb4 字符集。

它的通用性比 gbk,latin1 都要好。utf8 字符集存储汉字占用 3 个字节,如果遇到表情存储的要求,就可以使用 utf8mb4

6. select 查询表的时候只需要获取必要的字段,避免使用 select *。

这样可以减少网络带宽消耗,还有可能利用到覆盖索引

7. 所有字段定义中,默认都加上 not null 约束,避免出现 null。

在对该字段进行 select count() 统计计数时,可以让统计结果更准确,因为值为 null 的数据,不会被计算进去的。

8. 创建索引的时候不要在低基数列上建立索引,像 sex、status 这种字段上面。

要通过索引的选择性来判断 select count(distinct col1)/count(*) from table_name; 越接近 1,证明选择性越高,越适合创建索引。一般情况下,单表索引数量不要超过 4-5 个范围。

9. SQL语句中,尽量避免出现 or 子句

这种判断的子句可以让程序自行完成,不要交给数据库判断。也要避免使用 union,尽量采用 union all,减少了去重和排序的工作。


10. 时时做好监控工作,经常对线上 sql 语句,进行在线捕获进行分析。

可以利用 percona-toolkit 工具。

目前先写这么多,欢迎大家及时补充,其实好多工作都需要 DBA 和开发人员密切配合。新的业务要上线,DBA 就要参与到业务中,配合开发一起建表建模。我们只有一个目的,就是更舒服得工作,挣更多的钱,那为啥不能改变一下我们不好的工作习惯呢。工作中不是你想怎么着,就怎么着!继续努力吧!



更多精彩文章:

MySQL数据库“十宗罪”(十大经典错误案例)

数据库优化之降龙十八掌



我的在线课程:MySQL 体系结构深入剖析及实战 DBA 视频课程

课程目标

通过对 MySQL 体系结构深入剖析讲解,配合生产环境备份恢复,主从复制,高可用集群架构和优化等实战演练,让同学们可以对 MySQL 数据库有个由浅到深的认识。最后的课程部分还会对面试题总结进行讲解,有利于同学们可以找到理想的 MySQL DBA 的工作。

适用人群

刚接触MySQL数据库的同学,有一定运维经验的运维人员,想提高自己MySQL数据库水平的DBA。

时间: 2024-10-15 08:48:16

想要Freestyle?先要遵守 MySQL 这十大铁律!的相关文章

MySQL管理员珍藏:十大必备工具盘点

作者:dongdongzzcs 第1页: [IT168 专稿]本文的作者Daniel Nichter是MySQL工具的开发者,他为MySQL管理员推荐了十款必备工具.以下是全文内容: MySQL是一套需要大量辅助工具加以修复.诊断及优化的复杂系统.幸运的是,对于管理员来说,MySQL的高普及度吸引了大量软件开发商为其打造高品质的各类开源工具,内容涵盖MySQL系统的复杂性均衡.性能表现维持及稳定运行保障,而且其中大部分是免费工具. 下列十款开源工具对于使用MySQL的用户来说是极为宝贵的财富,其

多线程与MySQL(十)

1.1 多线程 在传统操作系统中,每个进程有一个地址空间,而且默认就有一个控制线程 线程顾名思义,就是一条流水线工作的过程,一条流水线必须属于一个车间,一个车间的工作过程是一个进程 车间负责把资源整合到一起,是一个资源单位,而一个车间内至少有一个流水线 流水线的工作需要电源,电源就相当于cpu 所以,进程只是用来把资源集中到一起(进程只是一个资源单位,或者说资源集合),而线程才是cpu上的执行单位. 多线程(即多个控制线程)的概念是,在一个进程中存在多个控制线程,多个控制线程共享该进程的地址空间

MySQL 8.0的十大新特性

今天,让我们看一下MySQL8.0提升数据库管理员工作效率的十大改进. 从一大堆特性你们找出十点并不太容易,以下是这十大特性: 1.临时表的改进 2.持续的全局变量 3.取消默认MyISAM系统表 4.UNDO空间回收 5.UTF8性能改进 6.取消Query Cache 7.原子DDL 8.更快.性能更好的Schema和Information Schema 9.角色管理 10.加密表空间中的REDO日志和UNDO日志都将被加密 临时表的改进 在MySQL5.7中,所有的临时表都被创建在一个叫"

mysql插入blob大文件

1,E:\MySQL\MySQL Server 5.7\my.ini    max_allowed_packet=40M 2,MySQL的四种BLOB类型 类型 大小(单位:字节)  TinyBlob 最大 255  Blob 最大 65K  MediumBlob 最大 16M  LongBlob 最大 4G mysql插入blob大文件,布布扣,bubuko.com

MYSQL数据库导入大数据量sql文件失败的解决方案

1.在讨论这个问题之前首先介绍一下什么是"大数据量sql文件". 导出sql文件.选择数据库-----右击选择"转储SQL文件"-----选择"结构和数据"  .保存文件db_mras.sql文件. 2.导入sql文件.在MYSQL中新建数据库db_mras.选择数据库-----右击选择"运行SQL文件"-----选择文件db_mras.sql,运行. 现在发现运行失败,提示错误"MySQL server has g

MySQL复制异常大扫盲:快速溯源与排查错误全解

MySQL复制异常大扫盲:快速溯源与排查错误全解https://mp.weixin.qq.com/s/0Ic8BnUokyOj7m1YOrk1tA 作者介绍王松磊,现任职于UCloud,从事MySQL数据库内核研发工作,主要负责UCloud云数据库UDB的内核故障排查工作以及数据库新特性的研发工作. 复制作为MySQL原生的数据同步功能,在MySQL高可用架构中起着至关重要的作用.本文梳理了MySQL高可用产品UDB在日常运维中遇到的复制问题,并总结了当复制发生异常时,排查复制异常的方法. 一.

mysql 生产库大表delete

mysql 生产库大表删除 一般线上业务增长较快,造成某些表达到分表的临界值,表行数超过2000w且查询频繁,如表业务没有较多的聚合查询的话,可以考虑按时间归档部分历史数据.现推荐2种本人之前使用过的删除方式. 按照主键或者索引拆分后分段执行,使用存储过程 需要注意这种大表删除,如果是在主库执行,尽量把会话改成语句格式,以保证不会出现复制延迟 语句如下:set session binlog_format='STATEMENT'; CREATE PROCEDURE sp_delete_data()

MySQL 存储过程删除大表

1.权限问题 alter routine 编辑或删除存储过程 create routine 建立存储过程 execute 创建存储过程 2.存储过程相关的一些命令 show procedure status\G 查看数据库中有哪些存储过程 show procedure status where db = 'db_name'\G 查看指定数据库(db_name)中有哪些存储过程 select name from mysql.proc where db = 'db_name'; 查看指定数据库(db

MySQL ibdata1占用空间大 释放MySQL ibdata1文件的空间

MySQL ibdata1占用空间大  释放MySQL ibdata1文件的空间 背景:最近公司一台服务器报警,磁盘空间报警超阀值.  原来mysql数据库数据目录特别大,前一篇文章中介绍的是变更mysql数据文件的目录,此文主要介绍如何把mysql占用的空间释放出来. 说明: mysql有多种存储引擎,比如MyISAM.InnoDB很常用. 如果用的InnoDB, 且使用mysql默认的配置文件,MySQL的数据都会存放在ibdata1文件中,经过一段时间此文件会变的非常大,占用大量磁盘空间.