当前位置: 首页 > news >正文

PHP MySQL 插入多条数据

PHP MySQL 插入多条数据

在Web开发中,PHP和MySQL的组合是非常常见的。PHP是一种服务器端脚本语言,而MySQL是一种流行的数据库管理系统。在许多情况下,我们可能需要一次性向MySQL数据库插入多条数据。这可以通过几种不同的方法实现,每种方法都有其优缺点。本文将详细介绍如何在PHP中向MySQL数据库插入多条数据,包括使用原生SQL语句、使用预处理语句以及使用ORM(对象关系映射)库。

使用原生SQL语句插入多条数据

最简单的方法是使用原生SQL语句。这种方法直接且易于理解,但可能存在SQL注入的风险,因此需要特别小心地处理用户输入。

<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDB";// 创建连接
$conn = new mysqli($servername, $username, $password, $dbname);// 检查连接
if ($conn->connect_error) {die("连接失败: " . $conn->connect_error);
}// SQL语句
$sql = "INSERT INTO MyGuests (firstname, lastname, email) VALUES ('John', 'Doe', 'john@example.com'), ('Mary', 'Moe', 'mary@example.com'), ('Julie', 'Dooley', 'julie@example.com')";if ($conn->multi_query($sql) === TRUE) {echo "新记录插入成功";
} else {echo "Error: " . $sql . "<br>" . $conn->error;
}$conn->close();
?>

使用预处理语句插入多条数据

为了防止SQL注入,我们可以使用预处理语句。这种方法不仅更安全,而且执行效率更高。

<?php
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "myDB";// 创建连接
$conn = new mysqli($servername, $username, $password, $dbname);// 检查连接
if ($conn->connect_error) {die("连接失败: " . $conn->connect_error);
}// 预处理语句
$stmt = $conn->prepare("INSERT INTO MyGuests (firstname, lastname, email) VALUES (?, ?, ?), (?, ?, ?), (?, ?, ?)");// 绑定参数
$stmt->bind_param("ssssssssss", $firstname1, $lastname1, $email1, $firstname2, $lastname2, $email2, $firstname3, $lastname3, $email3);// 设置参数值
$firstname1 = "John";
$lastname1 = "Doe";
$email1 = "john@example.com";
$firstname2 = "Mary";
$lastname2 = "Moe";
$email2 = "mary@example.com";
$firstname3 = "Julie";
$lastname3 = "Dooley";
$email3 = "julie@example.com";// 执行语句
$stmt->execute();echo "新记录插入成功";$stmt->close();
$conn->close();
?>

使用ORM库插入多条数据

ORM(对象关系映射)库,如Doctrine或Laravel的Eloquent,可以让我们以面向对象的方式处理数据库操作。这种方法更加安全,代码也更加清晰,但可能会稍微降低执行效率。

以Laravel的Eloquent为例:

<?phpuse Illuminate\Database\Capsule\Manager as Capsule;// 创建ORM实例
$capsule = new Capsule;// 配置数据库连接
$capsule->addConnection(['driver'    => 'mysql','host'      => 'localhost','database'  => 'myDB','username'  => 'username','password'  => 'password','charset'   => 'utf8','collation' => 'utf8_unicode_ci','prefix'    => '',
]);// 设置全局静态可访问
$capsule->setAsGlobal();// 启动Eloquent
$capsule->bootEloquent();// 创建数据模型
class Guest extends \Illuminate\Database\Eloquent\Model
{protected $table = 'myguests';protected $fillable = ['firstname', 'lastname', 'email'];
}// 插入多条数据
Guest::insert([['firstname' => 'John', 'lastname' => 'Doe', 'email' => 'john@example.com'],['firstname' => 'Mary', 'lastname' => 'Moe', 'email' => 'mary@example.com'],['firstname' => 'Julie', 'lastname' => 'Dooley', 'email' => 'julie@example.com'],
]);echo "新记录插入成功";

总结

向MySQL数据库插入多条数据是PHP开发中的常见任务。本文介绍了三种不同的方法:使用原生SQL语句、使用预处理语句以及使用ORM库。每种方法都有其适用场景,开发者应根据具体需求和安全性

http://www.lryc.cn/news/508703.html

相关文章:

  • Oracle安装报错:将配置数据上载到资料档案库时出错
  • JavaScript 中通过Array.sort() 实现多字段排序、排序稳定性、随机排序洗牌算法、优化排序性能,JS中排序算法的使用详解(附实际应用代码)
  • Deformable DETR:Deformable Transformers for End-to-End Object Detection论文学习
  • 机器学习-43-可解释性机器学习库LIME
  • 【Unity功能集】TextureShop纹理工坊(五)选区
  • Spring Cloud OpenFeign快速入门demo
  • 研发效能DevOps: Vite 使用 Element Plus
  • sfnt-pingpong -测试网络性能和延迟的工具
  • Kubernetes、Docker 和 Docker Registry 关系是是什么?
  • docker部署微信小程序自动构建发布和更新
  • 模仿elementui的Table,实现思路
  • Unity中使用环形缓冲区平滑抖动值
  • 【Yonghong 企业日常问题 06】上传的文件不在白名单,修改allow.jar.digest属性添加允许上传的文件SH256值?
  • SpringBoot使用 AOP 实现自定义日志记录并保存在Mysql
  • 谷歌开源最强天气预报AI模型 GenCast
  • C++打造局域网聊天室第十课: 客户端编程及数据发送
  • Nginx整合Lua脚本
  • 【C++】C++11 STL容器emplace方法原理剖析
  • QT-简单视觉框架代码
  • AI新书推荐:深度学习和大模型原理与实践(清华社)
  • [spring]处理器
  • 重温设计模式--中介者模式
  • 重温设计模式--设计模式七大原则
  • LeetCode429周赛T4
  • 详解MySQL在Windows上的安装
  • 【Python使用】嘿马python高级进阶全体系教程第10篇:静态Web服务器-返回固定页面数据,1. 开发自己的静态Web服务器【附代码文档】
  • 软件测试面试题和简历模板(面试前准备篇)
  • Linux 基本使用和程序部署
  • uniapp微信小程序,使用fastadmin完成一个一键获取微信手机号的功能
  • CSS系列(27)- 图形与滤镜详解