MySQL中的12个SQL编写规范

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
简介: SQL良好习惯提升查询清晰度、效率和安全性,包括使用EXPLAIN分析查询计划、DELETE/UPDATE时加LIMIT限制影响范围、为表和字段添加注释、关键字大写缩进、指定INSERT字段名、先测试后执行、表含主键及时间戳字段、Update/Delete需Where条件、用InnoDB引擎、避免SELECT *,选择UTF8字符集和规范索引命名。

img

编写SQL语句的良好习惯至关重要,原因如下:

  • 它们提高了查询的清晰度和可读性,使其更易于理解、维护和调试。
  • 优化的SQL查询可以显著提升查询效率,减少执行时间和资源消耗。
  • 遵循最佳实践可以保障安全性,防止SQL注入攻击,确保敏感数据的安全处理。
  • 保持SQL编写的一致性,有助于团队成员之间的有效协作,并支持数据库系统扩展,以应对日益增长的数据量和用户访问。

1. 始终使用EXPLAIN语句

开发SQL查询时,养成使用EXPLAIN的习惯至关重要。 特别要注意索引的使用效率。例如:

EXPLAIN SELECT * FROM employees WHERE department = 'Engineering';

“EXPLAIN”语句的输出将提供MySQL打算如何执行查询的详细信息,包括是否使用索引和操作顺序。输出可能如下所示:

+----+-------------+-----------+------+---------------+------+---------+------+------+-------------+
| id | selecttype | table     | type | possiblekeys | key  | keylen | ref  | rows | Extra       |
+----+-------------+-----------+------+---------------+------+---------+------+------+-------------+
| 1  | SIMPLE      | employees | ref  | department    | department| 14      | const| 100  | Using index |
+----+-------------+-----------+------+---------------+------+---------+------+------+-------------+

在这个例子中,MySQL显示它正在使用'department'索引来检索employees表中的数据,这对查询性能是有利的。

2. 执行DELETE/UPDATE时包含LIMIT

执行DELETE或UPDATE语句时,建议添加LIMIT语句。示例如下:

-- Delete only one row from the 'employees' table with a specific condition
DELETE FROM employees WHERE department = 'Engineering' LIMIT 100;
  • 添加LIMIT子句有助于减少错误SQL语句的影响。如果在命令行中执行SQL命令时忘记添加LIMIT,可能会不小心删除所有数据。
  • 通过添加例如LIMIT 200,可以将潜在的损害限制在一定范围内,以便在意外删除时通过binlog日志恢复最多200条记录。
  • 在SQL查询中使用LIMIT 1可以提高效率,因为它在找到第一个匹配项后停止查询执行,避免了不必要的表扫描。
  • 此外,包含LIMIT子句有助于避免在DELETE等操作期间的长时间事务,特别是在处理大型数据集时,可以防止CPU过载和性能下降。

3. 为表和字段添加适当的注释

设计数据库表时,养成为所有表和字段添加适当注释的习惯。 这种做法有助于未来维护,为数据库结构提供清晰的上下文。

示例如下:

CREATE TABLE `account` (
  `id` int(11) NOT NULL AUTOINCREMENT COMMENT '主键',
  `name` varchar(255) DEFAULT NULL COMMENT '账户名称',
  `balance` int(11) DEFAULT NULL COMMENT '账户余额',
  `createtime` datetime NOT NULL COMMENT '创建时间',
  `updatetime` datetime NOT NULL ON UPDATE CURRENTTIMESTAMP COMMENT '更新时间',
  PRIMARY KEY (`id`),
  KEY `idxname` (`name`) USING BTREE
) ENGINE=InnoDB AUTOINCREMENT=1570068 DEFAULT CHARSET=utf8 ROWFORMAT=REDUNDANT COMMENT='账户信息表';

4. 关键字大写并使用缩进

SQL书写规范中强调关键字大写和使用缩进,是为了提升代码的可读性和整洁度。关键字大写使得关键词更加醒目,便于快速识别,而缩进则清晰展现了语句结构,有助于理解代码逻辑,两者结合极大地增强了代码的可维护性和团队协作效率。

正例:

SELECT stu.name, SUM(stu.score)
FROM Student AS stu
WHERE stu.classNo = '10'
GROUP BY stu.name;

反例:

SELECT stu.name, sum(stu.score) from Student stu WHERE stu.classNo = '10' group by stu.name.

5. 在INSERT语句中指定字段名

这样做可以确保数据插入的准确性和健壮性。明确指定字段名能避免因表结构变动引发的错误,使得插入操作更加明确且易于维护,尤其是在表结构频繁调整的场景下。此外,这种方法还能提升代码的可读性,便于其他开发者理解插入操作的具体意图,以及在出现问题时快速定位和调试。

示例:

INSERT INTO Student (id, name, score) VALUES (123, 'user1', 100);

6. 先在测试环境中验证SQL

在执行任何SQL之前,先在测试环境中验证一次,然后再到生产环境中执行;这是因为:

  • 安全性:避免直接在生产环境执行可能影响数据完整性和安全性的SQL语句。
  • 错误检测:在测试环境中可以发现并修复SQL语句中的错误或性能问题,减少在生产环境中出现问题的风险。
  • 性能评估:测试环境中可以模拟生产环境的数据量和使用情况,评估SQL语句的性能,确保其在生产环境中的效率。
  • 影响控制:测试环境通常对业务影响较小,可以控制SQL变更的影响范围,避免对生产环境造成不必要的中断或损失。

7. 表中必须包含主键、创建时间、更新时间字段

这些字段在数据库设计中是常用的最佳实践,有助于提高数据的可靠性、可维护性和可追溯性。

  • 主键:主键是用于唯一标识表中每个记录的字段。它确保了每条记录的唯一性,并为数据库提供了快速的数据定位和索引。主键还用于建立数据表之间的关联关系,实现数据的一致性和完整性。
  • 创建时间:创建时间字段记录了每条记录的插入时间。它对于跟踪数据的创建顺序和时间线非常有用。创建时间可以用于数据分析、审计和排查问题,还可以帮助识别过时的数据或定期清理不再需要的数据。
  • 更新时间:更新时间字段记录了每条记录的最后一次更新时间。它对于追踪数据的变更、维护数据的一致性和追溯数据流动非常重要。更新时间可以用于监控数据的变化、检测数据的实效性,并支持数据恢复和修复操作。

示例 :

CREATE TABLE `exampletable` (
  `id` INT AUTOINCREMENT PRIMARY KEY,
  `name` VARCHAR(255),
  `createtime` TIMESTAMP DEFAULT CURRENTTIMESTAMP,
  `updatetime` TIMESTAMP DEFAULT CURRENTTIMESTAMP ON UPDATE CURRENTTIMESTAMP
);

8. Update和Delete语句必须要指定Where条件

执行Update和Delete语句时必须指定Where条件,是为了精确地定位并更改或删除数据库中指定的数据行,避免无差别地更改或删除所有数据,从而防止数据丢失或损坏,保证操作的准确性和安全性。同时可以减少数据库操作的范围,只对符合条件的数据行进行更新或删除。这样可以提高操作的执行效率,减少资源的消耗,提高操作的性能和效率。

示例:

-- Update the salary of the employee with ID 123
UPDATE employees SET salary = 60000 WHERE id = 123;

9. 使用InnoDB存储引擎

InnoDB是一种流行的MySQL存储引擎,它被广泛使用,主要因为它具有以下优点:

  • 事务支持:InnoDB是一个支持事务的存储引擎,它提供了ACID(原子性、一致性、隔离性和持久性)特性。这意味着你可以在InnoDB表上执行复杂的事务操作,确保数据的一致性和完整性。
  • 行级锁:与表级锁定相比,InnoDB的行级锁定可以提供更好的并发性能,因为它只锁定数据行而不是整个表。
  • 外键约束:InnoDB支持外键约束,可以在数据库层面实现关联表之间的数据完整性和一致性。外键可以帮助维护表与表之间的关系,并防止不一致或无效的数据关联。
  • 并发控制:InnoDB使用多版本并发控制(MVCC)来处理并发访问。这意味着它可以在不同的事务之间提供高度的隔离性,避免数据的冲突和锁竞争。
  • 崩溃恢复:InnoDB提供了崩溃恢复机制,可以在数据库发生故障或断电后自动进行恢复。

示例:

CREATE TABLE users (
    id INT AUTOINCREMENT PRIMARY KEY,
    name VARCHAR(100),
    email VARCHAR(100)
) ENGINE=InnoDB;

CREATE TABLE orders (
    id INT AUTOINCREMENT PRIMARY KEY,
    userid INT,
    amount DECIMAL(10, 2),
    createdat TIMESTAMP,
    FOREIGN KEY (userid) REFERENCES users(id)
) ENGINE=InnoDB;

10. 避免使用SELECT *

使用SELECT <特定字段>只检索所需要数据有以下好处:

  • 提高查询性能:只查询需要的字段可以减少数据库的工作量和查询时间。数据库不需要检索和处理不相关的数据列,可以更快地返回结果。
  • 减少网络传输量:因为从数据库服务器到客户端只需要传输实际需要的数据,这可以显著减少数据传输时间和带宽消耗。
  • 降低内存消耗:查询结果中只包含需要的字段可以减少应用程序的内存消耗。如果返回的数据集较大,只保留必要的字段可以减少内存使用量,并降低应用程序的内存压力。

11. 将UTF8作为数据库和表的字符集

设计数据库中的库和表时选择UTF8(更准确地说是UTF8MB4)作为字符集,主要原因如下:

  • 国际化支持:UTF8MB4字符集能够支持全球大多数语言的文字,包括各种特殊字符、表情符号等,这使得应用能够无障碍地服务于多语言环境下的用户。
  • 兼容性:UTF8MB4是UTF8的超集,它向下兼容UTF8,意味着使用UTF8MB4不会影响原有的UTF8数据,同时还能支持4字节的Unicode字符,确保了数据的完整性和广泛适用性。
  • 未来扩展性:UTF8是一种可扩展的字符集,它支持Unicode编码,并具备适应未来字符需求的能力。

12. 索引的命名规范

统一命名规范能让索引更易读、易懂,方便团队协作和维护,减少操作错误,利于自动化脚本处理,以及符合标准化要求,从而提升数据库的管理效率和系统稳定性。

  • 对于主键索引,使用“pk”作为前缀后跟字段名,如“pkid”表示“id”字段的主键索引,清晰表明此索引代表主键约束。

  • 对于唯一索引,使用“uk”作为前缀后跟字段名,如“ukemail”表示“email”字段的唯一索引,表示此索引强制字段上的唯一约束。

  • 对于常规索引,使用“idx”作为前缀后跟字段名,如“idxlastname”表示“lastname”字段的索引,用于优化指定字段的搜索。

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
2月前
|
存储 SQL 关系型数据库
mysql底层原理:索引、慢查询、 sql优化、事务、隔离级别、MVCC、redolog、undolog(图解+秒懂+史上最全)
mysql底层原理:索引、慢查询、 sql优化、事务、隔离级别、MVCC、redolog、undolog(图解+秒懂+史上最全)
mysql底层原理:索引、慢查询、 sql优化、事务、隔离级别、MVCC、redolog、undolog(图解+秒懂+史上最全)
|
3月前
|
SQL 关系型数据库 MySQL
Go语言数据库编程:使用 `database/sql` 与 MySQL/PostgreSQL
Go语言通过`database/sql`标准库提供统一数据库操作接口,支持MySQL、PostgreSQL等多种数据库。本文介绍了驱动安装、连接数据库、基本增删改查操作、预处理语句、事务处理及错误管理等内容,涵盖实际开发中常用的技巧与注意事项,适合快速掌握Go语言数据库编程基础。
215 62
|
4月前
|
SQL 数据采集 关系型数据库
实现MySQL与SQL Server之间数据迁移的有效方法
总的来说,从MySQL到SQL Server的数据迁移是一个涉及到很多步骤的过程,可能会遇到各种问题和挑战。但只要精心规划、仔细执行,这个任务是完全可以完成的。
269 18
|
5月前
|
SQL 关系型数据库 MySQL
【MySQL】SQL分析的几种方法
以上就是SQL分析的几种方法。需要注意的是,这些方法并不是孤立的,而是相互关联的。在实际的SQL分析中,我们通常需要结合使用这些方法,才能找出最佳的优化策略。同时,SQL分析也需要对数据库管理系统,数据,业务需求有深入的理解,这需要时间和经验的积累。
149 12
|
5月前
|
关系型数据库 MySQL 大数据
大数据新视界--大数据大厂之MySQL 数据库课程设计:MySQL 数据库 SQL 语句调优的进阶策略与实际案例(2-2)
本文延续前篇,深入探讨 MySQL 数据库 SQL 语句调优进阶策略。包括优化索引使用,介绍多种索引类型及避免索引失效等;调整数据库参数,如缓冲池、连接数和日志参数;还有分区表、垂直拆分等其他优化方法。通过实际案例分析展示调优效果。回顾与数据库课程设计相关文章,强调全面认识 MySQL 数据库重要性。为读者提供综合调优指导,确保数据库高效运行。
|
12月前
|
关系型数据库 MySQL 网络安全
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
|
SQL 存储 监控
SQL Server的并行实施如何优化?
【7月更文挑战第23天】SQL Server的并行实施如何优化?
406 13
解锁 SQL Server 2022的时间序列数据功能
【7月更文挑战第14天】要解锁SQL Server 2022的时间序列数据功能,可使用`generate_series`函数生成整数序列,例如:`SELECT value FROM generate_series(1, 10)。此外,`date_bucket`函数能按指定间隔(如周)对日期时间值分组,这些工具结合窗口函数和其他时间日期函数,能高效处理和分析时间序列数据。更多信息请参考官方文档和技术资料。
260 9
|
SQL 存储 网络安全
关系数据库SQLserver 安装 SQL Server
【7月更文挑战第26天】
165 6
|
存储 SQL C++
对比 SQL Server中的VARCHAR(max) 与VARCHAR(n) 数据类型
【7月更文挑战7天】SQL Server 中的 VARCHAR(max) vs VARCHAR(n): - VARCHAR(n) 存储最多 n 个字符(1-8000),适合短文本。 - VARCHAR(max) 可存储约 21 亿个字符,适合大量文本。 - VARCHAR(n) 在处理小数据时性能更好,空间固定。 - VARCHAR(max) 对于大文本更合适,但可能影响性能。 - 选择取决于数据长度预期和业务需求。
981 1

相关产品

  • 云数据库 RDS MySQL 版
  • 推荐镜像

    更多