How to develop a simple online ordering system using MySQL and Python
How to use MySQL and Python to develop a simple online ordering system
With the rapid development of the Internet, more and more people choose to order food online to solve their daily problems Dietary needs. In order to meet the needs of users, many companies have developed various online ordering systems. This article will introduce how to use MySQL and Python to develop a simple online ordering system and provide specific code examples.
First, we need to create a MySQL database to store menu information, user information and order information. The corresponding table can be created using the following SQL statement:
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 );
Next, we use Python and MySQL connection libraries to implement database connections and operations. The following is a code example for MySQL connection:
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()
Now we can query the menu from the database, implement user registration and login, and place orders.
In order for users to use the online ordering system, we need a simple user interface. The following is a code example using Python's Flask library to implement a simple web interface:
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()
The above code creates a simple web interface based on Flask, including the homepage, user registration page, user login page and order placement Page.
Finally, we need to create the corresponding html template file to present the web interface. Here is a simple example:
index.html:
<!DOCTYPE html> <html> <head> <title>Online Ordering System</title> </head> <body> {% for item in menu %} <h3 id="item">{{ 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 id="User-Registration">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 id="User-Login">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 id="Success">Success</h2> <p>Your order has been placed successfully.</p> </body> </html>
The above is a detailed code example of how to use MySQL and Python to develop a simple online ordering system. By referring to this example, you can further expand and optimize your online ordering system to suit your actual needs.
The above is the detailed content of How to develop a simple online ordering system using MySQL and Python. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

PHP is mainly procedural programming, but also supports object-oriented programming (OOP); Python supports a variety of paradigms, including OOP, functional and procedural programming. PHP is suitable for web development, and Python is suitable for a variety of applications such as data analysis and machine learning.

PHP is suitable for web development and rapid prototyping, and Python is suitable for data science and machine learning. 1.PHP is used for dynamic web development, with simple syntax and suitable for rapid development. 2. Python has concise syntax, is suitable for multiple fields, and has a strong library ecosystem.

The main role of MySQL in web applications is to store and manage data. 1.MySQL efficiently processes user information, product catalogs, transaction records and other data. 2. Through SQL query, developers can extract information from the database to generate dynamic content. 3.MySQL works based on the client-server model to ensure acceptable query speed.

Laravel is a PHP framework for easy building of web applications. It provides a range of powerful features including: Installation: Install the Laravel CLI globally with Composer and create applications in the project directory. Routing: Define the relationship between the URL and the handler in routes/web.php. View: Create a view in resources/views to render the application's interface. Database Integration: Provides out-of-the-box integration with databases such as MySQL and uses migration to create and modify tables. Model and Controller: The model represents the database entity and the controller processes HTTP requests.

PHP originated in 1994 and was developed by RasmusLerdorf. It was originally used to track website visitors and gradually evolved into a server-side scripting language and was widely used in web development. Python was developed by Guidovan Rossum in the late 1980s and was first released in 1991. It emphasizes code readability and simplicity, and is suitable for scientific computing, data analysis and other fields.

I encountered a tricky problem when developing a small application: the need to quickly integrate a lightweight database operation library. After trying multiple libraries, I found that they either have too much functionality or are not very compatible. Eventually, I found minii/db, a simplified version based on Yii2 that solved my problem perfectly.

Running Python code in Notepad requires the Python executable and NppExec plug-in to be installed. After installing Python and adding PATH to it, configure the command "python" and the parameter "{CURRENT_DIRECTORY}{FILE_NAME}" in the NppExec plug-in to run Python code in Notepad through the shortcut key "F6".

Python is easier to learn and use, while C is more powerful but complex. 1. Python syntax is concise and suitable for beginners. Dynamic typing and automatic memory management make it easy to use, but may cause runtime errors. 2.C provides low-level control and advanced features, suitable for high-performance applications, but has a high learning threshold and requires manual memory and type safety management.
