PHP中如何连接数据库并执行查询?

在 PHP 中,连接数据库并执行查询通常需要使用数据库扩展库。在大多数情况下,你可以使用以下两个扩展库:

  1. MySQLi(MySQL Improved):

    • MySQLi 是 MySQL 官方推荐的扩展库,提供了面向对象和面向过程两种方式。

    面向对象方式:

    $mysqli = new mysqli("localhost", "username", "password", "database");
    
    // 检查连接是否成功
    if ($mysqli->connect_error) {
         
        die("Connection failed: " . $mysqli->connect_error);
    }
    
    $sql = "SELECT * FROM your_table";
    $result = $mysqli->query($sql);
    
    // 处理查询结果
    while ($row = $result->fetch_assoc()) {
         
        // 处理每一行数据
    }
    
    // 关闭连接
    $mysqli->close();
    

    面向过程方式:

    $conn = mysqli_connect("localhost", "username", "password", "database");
    
    // 检查连接是否成功
    if (!$conn) {
         
        die("Connection failed: " . mysqli_connect_error());
    }
    
    $sql = "SELECT * FROM your_table";
    $result = mysqli_query($conn, $sql);
    
    // 处理查询结果
    while ($row = mysqli_fetch_assoc($result)) {
         
        // 处理每一行数据
    }
    
    // 关闭连接
    mysqli_close($conn);
    
  2. PDO(PHP Data Objects):

    • PDO 是一种通用的数据库访问层,支持多种数据库。它提供了一种统一的接口,可以使用不同的数据库驱动。
    $dsn = "mysql:host=localhost;dbname=database";
    $username = "username";
    $password = "password";
    
    try {
         
        $pdo = new PDO($dsn, $username, $password);
        $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    
        $sql = "SELECT * FROM your_table";
        $stmt = $pdo->query($sql);
    
        // 处理查询结果
        while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
         
            // 处理每一行数据
        }
    } catch (PDOException $e) {
         
        echo "Connection failed: " . $e->getMessage();
    } finally {
         
        // 关闭连接
        $pdo = null;
    }
    

上述示例中,你需要替换示例中的 “localhost”、“username”、“password” 和 “database” 为你的实际数据库连接信息。在实际应用中,为了安全性考虑,应该使用安全的数据库凭证,并考虑使用预处理语句来防止 SQL 注入攻击。

相关推荐

  1. PHP如何连接数据库执行查询

    2023-12-14 13:00:02       52 阅读
  2. Golang - 连接MySQL执行查询脚本

    2023-12-14 13:00:02       35 阅读
  3. 如何创建一个 Django 应用连接数据库

    2023-12-14 13:00:02       38 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-14 13:00:02       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-14 13:00:02       106 阅读
  3. 在Django里面运行非项目文件

    2023-12-14 13:00:02       87 阅读
  4. Python语言-面向对象

    2023-12-14 13:00:02       96 阅读

热门阅读

  1. 利用tf-idf对特征进行提取

    2023-12-14 13:00:02       57 阅读
  2. MFC程序中CStdioFile文件的读写

    2023-12-14 13:00:02       44 阅读
  3. Redis简易延时队列

    2023-12-14 13:00:02       65 阅读
  4. AI智能外呼系统销售特别注意的信息点

    2023-12-14 13:00:02       55 阅读
  5. Express中使用Swagger

    2023-12-14 13:00:02       66 阅读
  6. simulink自定义用户库、模块封装及案例测试

    2023-12-14 13:00:02       62 阅读
  7. web安全的基本概念及其应用场景

    2023-12-14 13:00:02       63 阅读