由于篇幅限制,以下仅展示如何使用PHP和MySQL创建一个简单的校园维修报修系统的核心功能。
// 数据库连接配置
define('DB_HOST', 'localhost');
define('DB_USER', 'root');
define('DB_PASS', 'password');
define('DB_NAME', 'repair_system');
// 连接数据库
$conn = new mysqli(DB_HOST, DB_USER, DB_PASS, DB_NAME);
// 检查连接
if ($conn->connect_error) {
die("连接失败: " . $conn->connect_error);
}
// 创建报修单函数
function createRepairOrder($conn, $studentId, $equipmentId, $description) {
$stmt = $conn->prepare("INSERT INTO repair_orders (student_id, equipment_id, description, status) VALUES (?, ?, ?, '待处理')");
$stmt->bind_param("iii", $studentId, $equipmentId, $description);
if ($stmt->execute()) {
return $stmt->insert_id; // 返回插入的报修单ID
} else {
return false;
}
}
// 获取报修单函数
function getRepairOrder($conn, $orderId) {
$stmt = $conn->prepare("SELECT * FROM repair_orders WHERE id = ?");
$stmt->bind_param("i", $orderId);
$stmt->execute();
$result = $stmt->get_result();
return $result->fetch_assoc();
}
// 更新报修单状态函数
function updateRepairOrderStatus($conn, $orderId, $status) {
$stmt = $conn->prepare("UPDATE repair_orders SET status = ? WHERE id = ?");
$stmt->bind_param("si", $status, $orderId);
return $stmt->execute();
}
// 示例使用
$studentId = 123;
$equipmentId = 456;
$description = "电脑故障,屏幕发热";
$orderId = createRepairOrder($conn, $studentId, $equipmentId, $description);
if ($orderId) {
echo "报修单创建成功,报修单ID:$orderId";
// 更新报修单状态为“处理中”
if (updateRepairOrderStatus($conn, $orderId, '处理中')) {
echo "报修单状态更新成功";
} else {
echo "报修单状态更新失败";
}
} else {
echo "报修单创建失败";
}
// 关闭数据库连接
$conn->close();
在这个简单的例子中,我们创建了一个用于连接MySQL数据库的小型函数库。这些函数包括创建报修单、获取报修单信息以及更新报修单状态。这样的设计可以帮助开发者理解如何安全地与数据库交互,同时也体现了面向对象编程的概念,这对于开发复杂系统是非常有用的。