Maison >développement back-end >tutoriel php >Utiliser PHP pour développer un système de planification des ressources d'entreprise (ERP) qui implémente des fonctions de suivi des commandes
Utilisez PHP pour développer un système de planification des ressources d'entreprise (ERP) qui implémente des fonctions de suivi des commandes
Le système de planification des ressources d'entreprise (ERP) est un système logiciel qui intègre diverses fonctions de gestion et peut aider les entreprises à gérer plus efficacement leurs processus commerciaux quotidiens. Parmi eux, la fonction de suivi des commandes est particulièrement importante pour les entreprises, car elle peut les aider à comprendre l'état et l'avancement des commandes en temps réel.
Dans cet article, nous allons développer une fonction simple de suivi des commandes en utilisant PHP et l'intégrer dans un système ERP de base.
Tout d'abord, nous devons créer une base de données et créer les tables correspondantes dans la base de données pour stocker les informations relatives aux commandes.
-- 创建订单表 CREATE TABLE orders ( id INT PRIMARY KEY AUTO_INCREMENT, order_number VARCHAR(50) NOT NULL, customer_name VARCHAR(100) NOT NULL, status ENUM('待处理', '处理中', '已完成') NOT NULL, created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ); -- 创建订单历史记录表 CREATE TABLE order_history ( id INT PRIMARY KEY AUTO_INCREMENT, order_id INT NOT NULL, status ENUM('待处理', '处理中', '已完成') NOT NULL, updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP, FOREIGN KEY (order_id) REFERENCES orders(id) );
Ensuite, nous créerons une classe PHP pour gérer les opérations liées aux commandes. Tout d’abord, nous devons définir une classe Order
, qui contient quelques propriétés et méthodes de base. Order
类,包含一些基本的属性和方法。
class Order { private $conn; public function __construct($conn) { $this->conn = $conn; } // 创建订单 public function createOrder($orderNumber, $customerName) { $status = '待处理'; $sql = "INSERT INTO orders (order_number, customer_name, status) VALUES (?, ?, ?)"; $stmt = $this->conn->prepare($sql); $stmt->bind_param("sss", $orderNumber, $customerName, $status); $stmt->execute(); $stmt->close(); } // 更新订单状态 public function updateOrderStatus($orderId, $status) { $sql = "UPDATE orders SET status = ? WHERE id = ?"; $stmt = $this->conn->prepare($sql); $stmt->bind_param("si", $status, $orderId); $stmt->execute(); $stmt->close(); // 记录订单状态变更历史 $this->recordOrderHistory($orderId, $status); } // 记录订单状态变更历史 private function recordOrderHistory($orderId, $status) { $sql = "INSERT INTO order_history (order_id, status) VALUES (?, ?)"; $stmt = $this->conn->prepare($sql); $stmt->bind_param("is", $orderId, $status); $stmt->execute(); $stmt->close(); } // 获取订单详情 public function getOrderDetail($orderId) { $sql = "SELECT o.*, oh.status AS history_status, oh.updated_at AS history_updated_at FROM orders o LEFT JOIN order_history oh ON o.id = oh.order_id WHERE o.id = ?"; $stmt = $this->conn->prepare($sql); $stmt->bind_param("i", $orderId); $stmt->execute(); $result = $stmt->get_result(); $orderDetail = $result->fetch_assoc(); $stmt->close(); return $orderDetail; } }
接下来,我们将使用上述Order
// 初始化数据库连接 $servername = "localhost"; $username = "root"; $password = ""; $dbname = "erp"; $conn = new mysqli($servername, $username, $password, $dbname); if ($conn->connect_error) { die("连接数据库失败:" . $conn->connect_error); } $order = new Order($conn); // 创建订单 $order->createOrder("202101010001", "张三"); // 更新订单状态为处理中 $order->updateOrderStatus(1, '处理中'); // 更新订单状态为已完成 $order->updateOrderStatus(1, '已完成'); // 获取订单详情 $orderDetail = $order->getOrderDetail(1);3. Implémentez la fonction de suivi des commandesEnsuite, nous utiliserons la classe
Order
ci-dessus pour implémenter la fonction de suivi des commandes. Sur la page, nous afficherons les informations de base et les enregistrements historiques de changement de statut de la commande. Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!