当前位置:首页 > PHP

php实现分数查询

2026-02-16 11:14:09PHP

实现分数查询功能

在PHP中实现分数查询功能通常涉及数据库操作和前端展示。以下是一个完整的实现方案,涵盖数据库设计、查询逻辑和前端展示。

数据库设计

创建一个名为scores的表,包含学生信息和分数字段:

CREATE TABLE scores (
    id INT AUTO_INCREMENT PRIMARY KEY,
    student_name VARCHAR(50) NOT NULL,
    student_id VARCHAR(20) NOT NULL,
    subject VARCHAR(30) NOT NULL,
    score FLOAT NOT NULL,
    exam_date DATE
);

连接数据库

使用PDO建立数据库连接:

php实现分数查询

$host = 'localhost';
$dbname = 'score_db';
$username = 'root';
$password = '';

try {
    $pdo = new PDO("mysql:host=$host;dbname=$dbname", $username, $password);
    $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
} catch(PDOException $e) {
    die("数据库连接失败: " . $e->getMessage());
}

查询功能实现

创建查询表单页面(search_form.php):

<form action="search_results.php" method="get">
    <label for="student_id">学号:</label>
    <input type="text" id="student_id" name="student_id" required>

    <label for="subject">科目:</label>
    <select id="subject" name="subject">
        <option value="">全部科目</option>
        <option value="数学">数学</option>
        <option value="语文">语文</option>
        <option value="英语">英语</option>
    </select>

    <button type="submit">查询</button>
</form>

创建结果展示页面(search_results.php):

php实现分数查询

$student_id = $_GET['student_id'] ?? '';
$subject = $_GET['subject'] ?? '';

$sql = "SELECT * FROM scores WHERE student_id = :student_id";
$params = [':student_id' => $student_id];

if (!empty($subject)) {
    $sql .= " AND subject = :subject";
    $params[':subject'] = $subject;
}

$stmt = $pdo->prepare($sql);
$stmt->execute($params);
$results = $stmt->fetchAll(PDO::FETCH_ASSOC);

if (count($results) > 0) {
    echo "<table border='1'>";
    echo "<tr><th>姓名</th><th>学号</th><th>科目</th><th>分数</th><th>考试日期</th></tr>";
    foreach ($results as $row) {
        echo "<tr>";
        echo "<td>{$row['student_name']}</td>";
        echo "<td>{$row['student_id']}</td>";
        echo "<td>{$row['subject']}</td>";
        echo "<td>{$row['score']}</td>";
        echo "<td>{$row['exam_date']}</td>";
        echo "</tr>";
    }
    echo "</table>";
} else {
    echo "未找到匹配的记录";
}

安全性增强

添加输入验证和防SQL注入措施:

$student_id = filter_input(INPUT_GET, 'student_id', FILTER_SANITIZE_STRING);
$subject = filter_input(INPUT_GET, 'subject', FILTER_SANITIZE_STRING);

if (empty($student_id)) {
    die("学号不能为空");
}

分页功能

对于大量数据结果,可以添加分页功能:

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

$sql = "SELECT SQL_CALC_FOUND_ROWS * FROM scores WHERE student_id = :student_id";
if (!empty($subject)) {
    $sql .= " AND subject = :subject";
}
$sql .= " LIMIT $limit OFFSET $offset";

// 执行查询后获取总记录数
$total_stmt = $pdo->query("SELECT FOUND_ROWS()");
$total = $total_stmt->fetchColumn();
$total_pages = ceil($total / $limit);

导出功能

添加导出为CSV的功能:

if (isset($_GET['export'])) {
    header('Content-Type: text/csv');
    header('Content-Disposition: attachment; filename="scores.csv"');

    $output = fopen('php://output', 'w');
    fputcsv($output, ['姓名', '学号', '科目', '分数', '考试日期']);

    foreach ($results as $row) {
        fputcsv($output, $row);
    }

    fclose($output);
    exit;
}

这个实现方案提供了完整的分数查询功能,包括数据库设计、查询表单、结果展示、安全措施和额外功能。可以根据实际需求进行调整和扩展。

标签: 分数php
分享给朋友:

相关文章

php实现增删改查

php实现增删改查

以下是在PHP中实现增删改查(CRUD)操作的详细方法,以MySQL数据库为例: 数据库连接配置 创建config.php文件存储数据库连接信息: <?php $host = 'localh…

php实现分类

php实现分类

PHP实现分类的方法 数据库设计 创建分类表时,通常需要包含id、名称、父级id等字段。父级id用于实现多级分类结构。 CREATE TABLE categories ( id INT AU…

php实现统计

php实现统计

PHP 实现统计功能 在 PHP 中实现统计功能通常涉及数据的收集、处理和展示。以下是一些常见的统计实现方法: 数据库数据统计 通过 SQL 查询可以直接从数据库中获取统计结果: $conn =…

php 实现队列

php 实现队列

PHP 实现队列的方法 PHP 可以通过多种方式实现队列功能,以下是几种常见的实现方法: 使用数组实现队列 PHP 数组可以通过 array_push 和 array_shift 函数模拟队列的先进…

php 实现单点登录

php 实现单点登录

PHP 实现单点登录的方法 单点登录(SSO)允许用户通过一次登录访问多个相互信任的系统。以下是基于 PHP 的实现方案: 基于共享 Session 的方案 在同一个主域名下的子域名间可以通过共享…

php实现短信验证

php实现短信验证

PHP实现短信验证的步骤 选择合适的短信服务提供商 国内常见的短信服务提供商包括阿里云短信、腾讯云短信、云片等。注册账号并获取API密钥和签名模板是第一步。这些平台通常提供详细的开发文档和SDK。…