当前位置:首页 > PHP

php实现查询

2026-02-14 00:06:37PHP

PHP 实现数据库查询

PHP 中实现数据库查询通常使用 PDO(PHP Data Objects)或 MySQLi 扩展。以下分别介绍两种方法的实现方式。

使用 PDO 进行查询

PDO 提供了一个数据访问抽象层,支持多种数据库。

<?php
$host = 'localhost';
$db   = 'database_name';
$user = 'username';
$pass = 'password';
$charset = 'utf8mb4';

$dsn = "mysql:host=$host;dbname=$db;charset=$charset";
$options = [
    PDO::ATTR_ERRMODE            => PDO::ERRMODE_EXCEPTION,
    PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
    PDO::ATTR_EMULATE_PREPARES   => false,
];

try {
    $pdo = new PDO($dsn, $user, $pass, $options);

    $stmt = $pdo->query('SELECT * FROM users');
    while ($row = $stmt->fetch()) {
        echo $row['name'] . "\n";
    }
} catch (PDOException $e) {
    throw new PDOException($e->getMessage(), (int)$e->getCode());
}
?>

使用 MySQLi 进行查询

MySQLi 是专门为 MySQL 设计的扩展。

php实现查询

<?php
$host = 'localhost';
$user = 'username';
$pass = 'password';
$db = 'database_name';

$mysqli = new mysqli($host, $user, $pass, $db);

if ($mysqli->connect_errno) {
    echo "Failed to connect to MySQL: " . $mysqli->connect_error;
    exit();
}

$result = $mysqli->query("SELECT * FROM users");
while ($row = $result->fetch_assoc()) {
    echo $row['name'] . "\n";
}

$mysqli->close();
?>

预处理语句防止 SQL 注入

预处理语句是防止 SQL 注入的最佳实践。

PDO 预处理

$stmt = $pdo->prepare('SELECT * FROM users WHERE id = ?');
$stmt->execute([$id]);
$user = $stmt->fetch();

MySQLi 预处理

$stmt = $mysqli->prepare("SELECT * FROM users WHERE id = ?");
$stmt->bind_param("i", $id);
$stmt->execute();
$result = $stmt->get_result();
$user = $result->fetch_assoc();

处理查询结果

查询结果可以以不同方式获取:

php实现查询

// 获取所有结果
$users = $stmt->fetchAll(PDO::FETCH_ASSOC);

// 获取单行
$user = $stmt->fetch(PDO::FETCH_ASSOC);

// 获取列
$count = $stmt->fetchColumn();

错误处理

良好的错误处理机制对数据库操作至关重要。

try {
    // 数据库操作
} catch (PDOException $e) {
    error_log($e->getMessage());
    // 显示用户友好信息
}

连接管理

数据库连接应在脚本结束时关闭。

// PDO 不需要显式关闭
// MySQLi 需要关闭
$mysqli->close();

以上方法涵盖了 PHP 中实现数据库查询的基本操作,可根据具体需求选择适合的方式。

标签: php
分享给朋友:

相关文章

php实现分页

php实现分页

PHP实现分页的基本方法 使用原生PHP实现分页功能需要结合数据库查询和HTML展示。以下是核心实现步骤: 数据库查询与分页逻辑 // 连接数据库 $conn = new mysqli('loca…

php实现文件下载

php实现文件下载

PHP实现文件下载的方法 通过PHP实现文件下载功能,可以采用多种方式,以下是几种常见的实现方法: 使用header()函数强制下载 设置HTTP头信息,强制浏览器下载文件而非直接打开: $fi…

php实现验证码

php实现验证码

PHP实现验证码的方法 使用GD库生成验证码 GD库是PHP中处理图像的扩展,可用于生成验证码图片。 <?php session_start(); $width = 120; $height…

php实现图片上传

php实现图片上传

实现图片上传的基本步骤 创建HTML表单用于文件上传,表单需设置enctype="multipart/form-data"属性,确保文件数据正确传输。 <form action="upload…

php验证码实现

php验证码实现

验证码实现方法 在PHP中实现验证码功能通常涉及生成随机字符串或数字,将其转换为图像,并通过会话(Session)进行验证。以下是几种常见的实现方式: 使用GD库生成图像验证码 GD库是PHP内置…

php实现搜索

php实现搜索

PHP实现搜索功能的方法 在PHP中实现搜索功能通常涉及数据库查询和用户输入的匹配。以下是几种常见的实现方式: 使用MySQL LIKE语句 通过简单的LIKE语句实现基础搜索: $searchT…