如何在 PHP 中独立执行多个 MySQL 查询?
使用 PHP 将多个 MySQL 查询作为一个执行
问题:
您需要执行两个单独的 MySQL 查询并处理他们的结果在 PHP 中独立。查询是:
SELECT SQL_CALC_FOUND_ROWS Id, Name FROM my_table WHERE Name LIKE '%prashant%' LIMIT 0, 10; SELECT FOUND_ROWS();
登录后复制
答案:
在 PHP 中使用标准 mysql_ 扩展,不可能将多个查询作为单个事务执行。但是,您可以通过以下步骤获得所需的结果:
- 执行第一个查询:
$query1 = "SELECT SQL_CALC_FOUND_ROWS Id, Name FROM my_table WHERE Name LIKE '%prashant%' LIMIT 0, 10;"; $result1 = mysql_query($query1);
登录后复制
- 执行第二个查询:
$query2 = "SELECT FOUND_ROWS();"; $result2 = mysql_query($query2);
登录后复制
- 获取第一个查询的结果:
$rows1 = mysql_fetch_all($result1, MYSQL_ASSOC);
登录后复制
- 获取第二次的结果query:
$totalRows = mysql_fetch_row($result2)[0];
登录后复制
通过执行以下步骤,您可以独立执行两个查询并单独处理它们的结果。请注意,这种方法不如将它们作为单个事务执行那么有效,但这是使用 mysql_ 扩展实现所需结果的唯一方法。
替代解决方案(已弃用):
更新: 以前认为可以使用 mysql_connect() 函数在一条语句中执行多个查询带有旗帜。但是,此方法已被弃用,不应使用。
现代解决方案:
对于现代 PHP 应用程序,建议使用 PDO(PHP 数据) Objects) 用于数据库交互的扩展。 PDO 提供了一种更加面向对象且一致的方式来执行 SQL 查询并检索其结果。使用 PDO,您可以按如下方式执行两个查询:
$pdo = new PDO('mysql:host=localhost;dbname=your_database', 'username', 'password'); $stmt1 = $pdo->prepare($query1); $stmt2 = $pdo->prepare($query2); $stmt1->execute(); $rows1 = $stmt1->fetchAll(PDO::FETCH_ASSOC); $stmt2->execute(); $totalRows = $stmt2->fetchColumn();
登录后复制
此解决方案比旧的 mysql_ 扩展更高效且更易于使用。
以上是如何在 PHP 中独立执行多个 MySQL 查询?的详细内容。更多信息请关注PHP中文网其他相关文章!
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前
By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
4 周前
By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前
By 尊渡假赌尊渡假赌尊渡假赌
击败分裂小说需要多长时间?
3 周前
By DDD
R.E.P.O.保存文件位置:在哪里以及如何保护它?
3 周前
By DDD

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)