当前位置:首页 > PHP

php实现网页数据查询

2026-02-14 05:43:27PHP

PHP 实现网页数据查询的方法

连接数据库

使用 PHP 内置的 mysqliPDO 扩展连接数据库。mysqli 适用于 MySQL 数据库,PDO 支持多种数据库类型。

// 使用 mysqli 连接 MySQL 数据库
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "database_name";

$conn = new mysqli($servername, $username, $password, $dbname);

if ($conn->connect_error) {
    die("连接失败: " . $conn->connect_error);
}

执行 SQL 查询

通过 SQL 语句查询数据库中的数据,并将结果存储在变量中。

$sql = "SELECT id, name, email FROM users";
$result = $conn->query($sql);

if ($result->num_rows > 0) {
    while($row = $result->fetch_assoc()) {
        echo "ID: " . $row["id"]. " - Name: " . $row["name"]. " - Email: " . $row["email"]. "<br>";
    }
} else {
    echo "0 结果";
}

处理查询结果

使用循环遍历查询结果,并将数据输出到网页上。fetch_assoc() 方法以关联数组形式返回每一行数据。

关闭数据库连接

查询完成后,关闭数据库连接以释放资源。

php实现网页数据查询

$conn->close();

使用 PDO 实现查询

PDO 提供了更灵活的数据库操作方式,支持预处理语句,防止 SQL 注入。

try {
    $conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);
    $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

    $stmt = $conn->prepare("SELECT id, name, email FROM users");
    $stmt->execute();

    $result = $stmt->fetchAll(PDO::FETCH_ASSOC);
    foreach ($result as $row) {
        echo "ID: " . $row["id"]. " - Name: " . $row["name"]. " - Email: " . $row["email"]. "<br>";
    }
} catch(PDOException $e) {
    echo "错误: " . $e->getMessage();
}
$conn = null;

通过表单提交查询条件

在网页上添加表单,允许用户输入查询条件,通过 $_GET$_POST 获取用户输入并动态生成 SQL 查询。

php实现网页数据查询

<form method="post" action="search.php">
    <input type="text" name="search_term" placeholder="输入查询关键词">
    <input type="submit" value="查询">
</form>
$search_term = $_POST['search_term'];
$sql = "SELECT * FROM users WHERE name LIKE '%$search_term%' OR email LIKE '%$search_term%'";

分页显示查询结果

对于大量数据,可以通过分页提高用户体验。使用 LIMITOFFSET 实现分页查询。

$per_page = 10;
$page = isset($_GET['page']) ? $_GET['page'] : 1;
$offset = ($page - 1) * $per_page;

$sql = "SELECT * FROM users LIMIT $per_page OFFSET $offset";
$result = $conn->query($sql);

使用 AJAX 实现无刷新查询

通过 jQuery 或原生 JavaScript 发送 AJAX 请求,动态加载查询结果,无需刷新页面。

$("#search_form").submit(function(e) {
    e.preventDefault();
    $.ajax({
        type: "POST",
        url: "search.php",
        data: $(this).serialize(),
        success: function(response) {
            $("#results").html(response);
        }
    });
});

防止 SQL 注入

使用预处理语句或过滤用户输入,避免 SQL 注入攻击。

$stmt = $conn->prepare("SELECT * FROM users WHERE name = ?");
$stmt->bind_param("s", $search_term);
$stmt->execute();

以上方法涵盖了从基础到进阶的网页数据查询实现方式,适用于大多数 PHP 网页开发场景。

分享给朋友:

相关文章

css网页尾部制作

css网页尾部制作

CSS网页尾部制作方法 固定定位底部布局 使用position: fixed将尾部固定在页面底部,适用于需要常驻显示的场景。代码示例: footer { position: fixed;…

网页登录实现vue

网页登录实现vue

使用 Vue 实现网页登录功能 创建 Vue 项目 使用 Vue CLI 初始化项目,运行命令 vue create login-demo 选择默认配置或手动配置项目。 安装必要依赖如 axios…

vue实现网页聊天

vue实现网页聊天

Vue 实现网页聊天功能 基础结构搭建 使用 Vue CLI 或 Vite 创建项目,安装必要依赖: npm install vue socket.io-client 创建基础组件结构: &l…

vue实现登录网页

vue实现登录网页

实现登录页面的步骤 前端部分使用Vue.js框架 创建Vue项目并安装必要依赖: vue create login-page cd login-page npm install axios vue…

vue怎么实现网页跳转

vue怎么实现网页跳转

vue实现网页跳转的方法 使用router-link组件 通过Vue Router提供的<router-link>组件实现声明式导航,适合模板中使用: <router-link t…

vue实现网页预览功能

vue实现网页预览功能

实现网页预览功能的方案 在Vue中实现网页预览功能可以通过多种方式完成,包括使用iframe、第三方库或后端服务生成缩略图。以下是几种常见的方法: 使用iframe嵌入目标网页 通过iframe直接…