> 데이터 베이스 > MySQL 튜토리얼 > MySQL과 Python을 사용하여 간단한 온라인 주문 시스템을 개발하는 방법

MySQL과 Python을 사용하여 간단한 온라인 주문 시스템을 개발하는 방법

WBOY
풀어 주다: 2023-09-21 15:54:30
원래의
1183명이 탐색했습니다.

MySQL과 Python을 사용하여 간단한 온라인 주문 시스템을 개발하는 방법

MySQL 및 Python을 사용하여 간단한 온라인 음식 주문 시스템을 개발하는 방법

인터넷의 급속한 발전으로 인해 점점 더 많은 사람들이 일상적인 식단 요구 사항을 해결하기 위해 온라인으로 음식을 주문하고 있습니다. 사용자의 요구를 충족시키기 위해 많은 회사에서 다양한 온라인 주문 시스템을 개발했습니다. 이 기사에서는 MySQL과 Python을 사용하여 간단한 온라인 주문 시스템을 개발하는 방법을 소개하고 구체적인 코드 예제를 제공합니다.

먼저 메뉴 정보, 사용자 정보, 주문 정보를 저장할 MySQL 데이터베이스를 만들어야 합니다. 해당 테이블은 다음 SQL 문을 사용하여 생성할 수 있습니다.

CREATE TABLE IF NOT EXISTS `menu` (
  `id` INT AUTO_INCREMENT PRIMARY KEY,
  `name` VARCHAR(100) NOT NULL,
  `price` DECIMAL(10,2) NOT NULL
);
CREATE TABLE IF NOT EXISTS `users` (
  `id` INT AUTO_INCREMENT PRIMARY KEY,
  `username` VARCHAR(100) NOT NULL,
  `password` VARCHAR(100) NOT NULL
);
CREATE TABLE IF NOT EXISTS `orders` (
  `id` INT AUTO_INCREMENT PRIMARY KEY,
  `user_id` INT NOT NULL,
  `menu_id` INT NOT NULL,
  `quantity` INT NOT NULL,
  `date` DATE NOT NULL
);
로그인 후 복사

다음으로 Python 및 MySQL 연결 라이브러리를 사용하여 데이터베이스 연결 및 작업을 구현합니다. 다음은 MySQL 연결에 대한 코드 예제입니다.

import mysql.connector

# 连接MySQL数据库
def connect_db():
    conn = mysql.connector.connect(
        host="localhost",
        user="your_username",
        password="your_password",
        database="your_database"
    )
    return conn

# 查询菜单
def get_menu():
    conn = connect_db()
    cursor = conn.cursor()
    cursor.execute("SELECT * FROM menu")
    menu = cursor.fetchall()
    cursor.close()
    conn.close()
    return menu

# 用户注册
def register(username, password):
    conn = connect_db()
    cursor = conn.cursor()
    cursor.execute("INSERT INTO users (username, password) VALUES (%s, %s)", (username, password))
    conn.commit()
    cursor.close()
    conn.close()

# 用户登录
def login(username, password):
    conn = connect_db()
    cursor = conn.cursor()
    cursor.execute("SELECT * FROM users WHERE username = %s AND password = %s", (username, password))
    user = cursor.fetchone()
    cursor.close()
    conn.close()
    return user

# 下订单
def place_order(user_id, menu_id, quantity, date):
    conn = connect_db()
    cursor = conn.cursor()
    cursor.execute("INSERT INTO orders (user_id, menu_id, quantity, date) VALUES (%s, %s, %s, %s)", (user_id, menu_id, quantity, date))
    conn.commit()
    cursor.close()
    conn.close()
로그인 후 복사

이제 데이터베이스에서 메뉴를 쿼리하고, 사용자 등록 및 로그인을 구현하고, 주문할 수 있습니다.

사용자가 온라인 주문 시스템을 사용하려면 간단한 사용자 인터페이스가 필요합니다. 다음은 Python의 Flask 라이브러리를 사용하여 간단한 웹 인터페이스를 구현하는 코드 예제입니다.

from flask import Flask, render_template, request
app = Flask(__name__)

# 用户界面
@app.route("/")
def index():
    menu = get_menu()
    return render_template("index.html", menu=menu)

# 用户注册
@app.route("/register", methods=["GET", "POST"])
def register_page():
    if request.method == "POST":
        username = request.form["username"]
        password = request.form["password"]
        register(username, password)
        return render_template("success.html")
    return render_template("register.html")

# 用户登录
@app.route("/login", methods=["GET", "POST"])
def login_page():
    if request.method == "POST":
        username = request.form["username"]
        password = request.form["password"]
        user = login(username, password)
        if user:
            return render_template("success.html")
        else:
            return render_template("login.html", error="Invalid username or password.")
    return render_template("login.html")

# 下订单
@app.route("/place_order", methods=["POST"])
def place_order_page():
    user_id = request.form["user_id"]
    menu_id = request.form["menu_id"]
    quantity = request.form["quantity"]
    date = request.form["date"]
    place_order(user_id, menu_id, quantity, date)
    return render_template("success.html")

if __name__ == "__main__":
    app.run()
로그인 후 복사

위 코드는 홈페이지, 사용자 등록 페이지, 사용자 로그인 페이지 및 주문 페이지를 포함하여 Flask 기반의 간단한 웹 인터페이스를 만듭니다.

마지막으로 웹 인터페이스를 표시하기 위해 해당 HTML 템플릿 파일을 만들어야 합니다. 다음은 간단한 예입니다.

index.html:

<!DOCTYPE html>
<html>
<head>
    <title>Online Ordering System</title>
</head>
<body>
    {% for item in menu %}
        <h3>{{ item[1] }}</h3>
        <p>Price: {{ item[2] }}</p>
        <form action="/place_order" method="post">
            <input type="hidden" name="user_id" value="1">
            <input type="hidden" name="menu_id" value="{{ item[0] }}">
            <input type="number" name="quantity" min="1" max="10" placeholder="Quantity" required>
            <input type="date" name="date" required>
            <button type="submit">Order</button>
        </form>
        <hr>
    {% endfor %}
</body>
</html>
로그인 후 복사

register.html:

<!DOCTYPE html>
<html>
<head>
    <title>User Registration</title>
</head>
<body>
    <h2>User Registration</h2>
    <form action="/register" method="post">
        <input type="text" name="username" placeholder="Username" required>
        <input type="password" name="password" placeholder="Password" required>
        <button type="submit">Register</button>
    </form>
</body>
</html>
로그인 후 복사

login.html:

<!DOCTYPE html>
<html>
<head>
    <title>User Login</title>
</head>
<body>
    <h2>User Login</h2>
    {% if error %}
        <p style="color:red;">{{ error }}</p>
    {% end %}
    <form action="/login" method="post">
        <input type="text" name="username" placeholder="Username" required>
        <input type="password" name="password" placeholder="Password" required>
        <button type="submit">Login</button>
    </form>
</body>
</html>
로그인 후 복사

success.html:

<!DOCTYPE html>
<html>
<head>
    <title>Success</title>
</head>
<body>
    <h2>Success</h2>
    <p>Your order has been placed successfully.</p>
</body>
</html>
로그인 후 복사

위는 MySQL을 사용하여 간단한 온라인 주문을 개발하는 방법과 Python 시스템에 대한 자세한 코드 예제입니다. 이 예를 참조하면 실제 요구 사항에 맞게 온라인 주문 시스템을 더욱 확장하고 최적화할 수 있습니다.

위 내용은 MySQL과 Python을 사용하여 간단한 온라인 주문 시스템을 개발하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿