首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysqli开启扩展

基础概念

mysqli 是 PHP 中的一个扩展,用于与 MySQL 数据库进行交互。它是 MySQL Improved Extension 的缩写,提供了对 MySQL 数据库服务器的连接、查询和操作功能。相比于早期的 mysql 扩展,mysqli 提供了更多的功能和更好的性能。

相关优势

  1. 面向对象接口mysqli 提供了面向对象的接口,使得代码更加清晰和易于维护。
  2. 预处理语句:支持预处理语句,可以有效防止 SQL 注入攻击。
  3. 事务支持:支持事务处理,确保数据的一致性和完整性。
  4. 多语句执行:可以同时执行多个 SQL 语句。
  5. 更好的性能:相比于 mysql 扩展,mysqli 在性能上有显著提升。

类型

mysqli 扩展主要分为两类:

  1. 面向对象的接口:使用 mysqli 类及其方法进行数据库操作。
  2. 过程式接口:使用函数进行数据库操作。

应用场景

mysqli 扩展广泛应用于各种需要与 MySQL 数据库交互的 PHP 应用中,例如:

  • Web 应用程序
  • RESTful API
  • 数据分析工具
  • 内容管理系统(CMS)

开启 mysqli 扩展

要在 PHP 中开启 mysqli 扩展,需要进行以下步骤:

在 Linux 系统上

  1. 编辑 PHP 配置文件
  2. 编辑 PHP 配置文件
  3. 取消注释 mysqli 扩展
  4. 取消注释 mysqli 扩展
  5. 改为:
  6. 改为:
  7. 重启 Apache 服务器
  8. 重启 Apache 服务器

在 Windows 系统上

  1. 编辑 php.ini 文件: 找到 PHP 安装目录下的 php.ini 文件。
  2. 取消注释 mysqli 扩展
  3. 取消注释 mysqli 扩展
  4. 改为:
  5. 改为:
  6. 重启 Web 服务器: 根据使用的 Web 服务器(如 Apache 或 IIS)重启相应的服务。

常见问题及解决方法

问题:无法连接到 MySQL 数据库

原因

  • 数据库服务器未启动。
  • 数据库连接参数错误。
  • mysqli 扩展未正确开启。

解决方法

  1. 确保 MySQL 服务器已启动并运行。
  2. 检查数据库连接参数(如主机名、端口、用户名、密码等)是否正确。
  3. 确认 mysqli 扩展已正确开启。

问题:SQL 注入攻击

原因

  • 使用不安全的 SQL 查询方式。
  • 未使用预处理语句。

解决方法

  1. 使用预处理语句(如 mysqli_preparemysqli_stmt_bind_param)来防止 SQL 注入攻击。
  2. 避免直接拼接 SQL 查询字符串。

示例代码

以下是一个简单的示例,展示如何使用 mysqli 连接到 MySQL 数据库并执行查询:

代码语言:txt
复制
<?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("SELECT id, firstname, lastname FROM MyGuests WHERE firstname=? AND lastname=?");
$stmt->bind_param("ss", $firstname, $lastname);

$firstname = "John";
$lastname = "Doe";

$stmt->execute();

$result = $stmt->get_result();

while ($row = $result->fetch_assoc()) {
    echo "id: " . $row["id"]. " - Name: " . $row["firstname"]. " " . $row["lastname"]. "<br>";
}

$stmt->close();
$conn->close();
?>

参考链接

希望以上信息对你有所帮助!

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

PHP中的MySQLi扩展学习(一)MySQLi介绍

PHP中的MySQLi扩展学习(一)MySQLi介绍 关于 PDO 的学习我们告一段落,从这篇文章开始,我们继续学习另外一个 MySQL 扩展,也就是除了 PDO 之外的最核心的 MySQLi 扩展。...现在如果想要使用过程式的代码来操作数据库,只能使用 mysqli 扩展了。当然,mysqli 扩展也是支持面向对象式的写法的。...什么是 MySQLi MySQLi 扩展允许我们访问 MySQL4.1 及以上版本的数据库所提供的功能。...扩展的安装及 MySQL8 需要注意的地方 MySQLi扩展是随 PHP 源码一起发布的,我们在编译 PHP 的时候加上 --with-mysqli 就可以了。...在接下来的文章中,我们将默认只使用 面向对象 式的写法来继续学习 MySQLi 扩展相关的知识。

2.9K20
  • PHP中的MySQLi扩展学习(六)MySQLI_result对象操作

    PHP中的MySQLi扩展学习(六)MySQLI_result对象操作 在之前的文章中,我们就已经接触过 MYSQLI_result 相关的内容。它的作用其实就是一个查询的结果集。...但在 MySQLi 中,会把查询到的结果也放入一个对象中,这就是 MySQLI_result 对象。...总结 至此,MySQLi 相关扩展的学习我们也就告一段落了,其它的一些类和函数比如 MySQLI_Driver 、 MySQLI_Exception 之类的内容大家可以自行查阅相关的文档,内容都不是很多...总体来说,整个 PHP 中和 MySQL 打交道的官方扩展我们就已经全部学习完了,PDO 和 MYSQLi 这两个扩展大家更主要的还是要掌握它们的区别和联系。...测试代码: https://github.com/zhangyue0503/dev-blog/blob/master/php/202009/source/9.PHP中的MySQLi扩展学习(六)MySQLI_result

    2.9K10

    PHP中的MySQLi扩展学习(四)mysqli的事务与预处理语句

    对于 MySQLi 来说,事务和预处理语句当然是它之所以能够淘汰 MySQL(原始) 扩展的资本。我们之前也已经学习过了 PDO 中关于事务和预处理语句相关的内容。...所以在这里,我们就不再多讲理论方面的东西了,直接上代码来看看 MySQLi 中这两大特性与 PDO 在使用上的区别。 事务处理 首先,我们还是要让 MySQLi 对于错误的语句也报出异常来。...而在 MySQLi 中,我们则需要指定 MySQLi_Driver 对象中的报错属性为抛出异常,很明显,MySQLi_Driver 就是 MySQLi 的驱动对象。...// 使用异常处理错误情况 $driver = new mysqli_driver(); $driver->report_mode = MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT...; 这样就指定了在使用 MySQLi 扩展时,所有的错误信息都会作为异常抛出。

    2.4K00

    PHP中的MySQLi扩展学习(五)MySQLI_STMT对象操作

    PHP中的MySQLi扩展学习(五)MySQLI_STMT对象操作 就像 PDO 中的 PDO_Statment 对象一样,MySQLI_STMT 对象也是一个预处理语句所形成的对象,专门用来操作 MySQLi...; $username='mysqli_username'; $password='mysqli_password'; $salt = 'mysqli_salt'; $stmt->bind_param...; $id = 's'; $username='mysqli_username'; $password='mysqli_password'; $salt = 'mysqli_salt'; $stmt-...可以看出,MySQLI_STMT 的错误属性和信息基本和 MySQLi 对象的是一样的。 列绑定 除了请求查询语句参数的绑定之外,MySQLI_STMT 也是支持直接绑定列的。...测试代码: https://github.com/zhangyue0503/dev-blog/blob/master/php/202009/source/8.PHP中的MySQLi扩展学习(五)MySQLI_STMT

    2.1K10

    PHP数据库扩展mysql、mysqli及pdo

    > 从PHP5.0开始就不推荐使用mysql_connect()函数,到了php7.0则直接废弃了该函数,替代的函数是:mysqli_connect(); 2、mysqli(mysql improved...php $conn = mysqli_connect("127.0.0.1", "root", "", "test") or die("Mysql connect error".mysqli_connect_error...()); $res = mysqli_query($conn, "select * from user"); while ($row = $res->fetch_object()) {...> 4、mysql是非持续连接函数而mysqli是永远连接函数。mysql每次连接都会打开一个连接的进程而mysqli多次运行mysqli将使用同一连接进程,从而减少了服务器的开销。...5、由于PDO能够支持其它非MySQL的数据库,而MySQLi专门针对MySQL设计的,所以MySQLi相对于PDO性能稍微好一些。但是PDO和MySQLi都还是没有PHP原生的MySQL扩展快。

    3.5K70

    PHP中的MySQLi扩展学习(二)mysqli类的一些少见的属性方法

    PHP中的MySQLi扩展学习(二)mysqli类的一些少见的属性方法 虽说是少见的一些属性方法,但是可能还是有不少同学在日常的开发中使用过,这里只是学习了可能相对来说我们用得比较少的一些 mysqli...就当是扩展一下自己的知识体系。 切换用户 首先就是切换一下当前连接数据库的用户。...$mysqli2 = @new mysqli("xxx", "root", "", "blog_test"); var_dump($mysqli2->connect_errno); // int(2002...mysqli 对象 上面说的很多属性其实我们可以直接通过打印 mysqli 对象就可以查看到。...测试代码: https://github.com/zhangyue0503/dev-blog/blob/master/php/202009/source/5.PHP中的MySQLi扩展学习(二)mysqli

    1.6K10

    PHP中的MySQLi扩展学习(二)mysqli类的一些少见的属性方法

    虽说是少见的一些属性方法,但是可能还是有不少同学在日常的开发中使用过,这里只是学习了可能相对来说我们用得比较少的一些 mysqli 的属性或方法。就当是扩展一下自己的知识体系。...通过打印 mysqli 的 error_list 属性就可以看到当前的错误信息。 错误信息 紧接着上一段,对于执行语句的错误信息,我们可以通过几个 mysqli 中的属性来获得。...$mysqli2 = @new mysqli("xxx", "root", "", "blog_test");var_dump($mysqli2->connect_errno); // int(2002...var_dump($mysqli->thread_safe); // NULLvar_dump($mysqli->thread_id); // int(600)$thread_id = $mysqli-...mysqli 对象 上面说的很多属性其实我们可以直接通过打印 mysqli 对象就可以查看到。

    2.2K00
    领券