技术文摘
MySQL 批量插入优化 SQL 执行效率实例代码
2025-01-15 04:18:51 小编
MySQL 批量插入优化 SQL 执行效率实例代码
在开发过程中,经常会遇到需要向 MySQL 数据库批量插入数据的场景。如果处理不当,会导致 SQL 执行效率低下,影响系统性能。本文将通过实例代码展示如何优化 MySQL 批量插入的 SQL 执行效率。
我们来看常规的批量插入方式。假设我们有一个 students 表,包含 id、name、age 三个字段。
CREATE TABLE students (
id INT AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(50),
age INT
);
常规的批量插入语句如下:
INSERT INTO students (name, age) VALUES ('张三', 20), ('李四', 22), ('王五', 25);
这种方式在数据量较小时尚可,但当数据量增大时,性能就会明显下降。因为每执行一次插入操作,数据库都需要进行一系列的检查、日志记录等操作,大量的小事务会增加系统开销。
接下来,我们采用优化后的方式。可以将多条数据合并成一个大的事务进行插入。
START TRANSACTION;
INSERT INTO students (name, age) VALUES ('张三', 20), ('李四', 22), ('王五', 25);
COMMIT;
通过将多条插入语句包含在一个事务中,数据库只需要进行一次事务相关的操作,大大减少了系统开销,提高了插入效率。
另外,还可以使用预处理语句来进一步优化。以 PHP 代码为例:
<?php
$servername = "localhost";
$username = "root";
$password = "";
$dbname = "test";
// 创建连接
$conn = new mysqli($servername, $username, $password, $dbname);
// 检查连接
if ($conn->connect_error) {
die("连接失败: ". $conn->connect_error);
}
// 预处理插入语句
$stmt = $conn->prepare("INSERT INTO students (name, age) VALUES (?,?)");
$data = [
['张三', 20],
['李四', 22],
['王五', 25]
];
foreach ($data as $row) {
$stmt->bind_param("si", $row[0], $row[1]);
$stmt->execute();
}
$stmt->close();
$conn->close();
?>
预处理语句不仅可以提高执行效率,还能有效防止 SQL 注入攻击。
通过合理运用事务和预处理语句等优化手段,能够显著提升 MySQL 批量插入的 SQL 执行效率,为系统的高效运行提供保障。在实际项目中,应根据具体的数据量和业务需求,选择最合适的优化方式。
- AJ-Captcha:图形验证码轻松集成
- 警惕!美国人或在基础软件上弯道超车
- Python 时序预测的常用方法代码实践
- Python 中数据类型转换的边界探寻与异常处置
- 北交开源 o1 代码版:强化学习与蒙特卡洛树搜索,源代码、精选数据集及衍生模型皆开源
- C++ 类型安全实战:规避 95% 运行时错误
- 代码标记助力性能飞升:谈 C++20 分支预测
- 深度剖析:C++发明引用的原因,指针真不够用?
- Spring Boot 性能飞跃的关键,速度猛增 500%!
- 怎样预防短信盗刷与短信轰炸
- 读写锁中线程读写的可行性探讨
- 如何动态调试线程池?我们一同探讨
- Python 自动化脚本:让日常工作轻松的十个秘诀
- 2024 年 CSS 持续发力 年终大盘点
- CRTP 助力代码高效 告别运行时多态