使用 mysql 保存数据,实现超市日常管理中以下业务。" 一、建立以下数据表并填充数据+登录+' 用户表: users _学号后四位+' 列名: id _学号后四位用户名 name 学号后四位密码: pwd _学号后四位*产品表: products _学号后四位. 列名: id _学号后四位编号 num 学号后四位名称 name 学号后四位单价 price 学号后四位折扣 discount _学号后四位 订单表: orders _学号后四位. 列名: id _学号后四位编号 num 学号后四位货品数量 count 学号后四位金额 arnount 学号后四位. 二、实现以下菜单并实现业务0用户登录 1查看所有产品信息。"2查找商品(用户输入商品名称,查看价格和折扣):- 3添加商品(需要程序生成编号),- 4修改商品价格和折扣(折扣为0.1-0.99之间):. 5删除商品(根据编号): 6查看所有订单:+ 7.订单统计(显示总销售额和货品数量): 8.商品结算。,每个声明的变量加上_0314结尾,并且所有自定义的变量加上_0314,例如a_0314=1,。然后还要教我用navicat建立这个的数据库表
时间: 2024-02-03 18:03:53 浏览: 171
好的,首先我们来创建数据库和表。
1. 打开 Navicat,选择连接数据库的服务器。
2. 在菜单栏中选择“数据库” -> “新建数据库”,输入数据库名,例如“market_0314”,选择字符集为“utf8mb4”,点击“确定”。
3. 在“market_0314”数据库中右键选择“新建表”,创建用户表“users_0314”。
4. 在“users_0314”表中新建字段“id_0314”(类型为int,长度为11,主键、自增)、“name_0314”(类型为varchar,长度为20)、“pwd_0314”(类型为varchar,长度为20)。
5. 创建产品表“products_0314”,在其中新建字段“id_0314”(类型为int,长度为11,主键、自增)、“num_0314”(类型为varchar,长度为10)、“name_0314”(类型为varchar,长度为20)、“price_0314”(类型为float,长度为10,小数位为2)、“discount_0314”(类型为float,长度为10,小数位为2)。
6. 创建订单表“orders_0314”,在其中新建字段“id_0314”(类型为int,长度为11,主键、自增)、“num_0314”(类型为varchar,长度为10)、“count_0314”(类型为int,长度为11)、“amount_0314”(类型为float,长度为10,小数位为2)。
接下来,我们开始编写代码来实现超市日常管理中的业务。
```python
import mysql.connector
# 登录功能
def login_0314():
username_0314 = input("请输入用户名:")
password_0314 = input("请输入密码:")
conn = mysql.connector.connect(user='root', password='123456', database='market_0314')
cursor = conn.cursor()
sql = "SELECT * FROM users_0314 WHERE name_0314=%s AND pwd_0314=%s"
cursor.execute(sql, (username_0314, password_0314))
result = cursor.fetchall()
if len(result) == 1:
print("登录成功!")
else:
print("用户名或密码错误!")
cursor.close()
conn.close()
# 查看所有产品信息功能
def show_all_products_0314():
conn = mysql.connector.connect(user='root', password='123456', database='market_0314')
cursor = conn.cursor()
sql = "SELECT * FROM products_0314"
cursor.execute(sql)
result = cursor.fetchall()
for r in result:
print(r)
cursor.close()
conn.close()
# 查找商品功能
def search_product_0314():
product_name_0314 = input("请输入商品名称:")
conn = mysql.connector.connect(user='root', password='123456', database='market_0314')
cursor = conn.cursor()
sql = "SELECT price_0314, discount_0314 FROM products_0314 WHERE name_0314=%s"
cursor.execute(sql, (product_name_0314,))
result = cursor.fetchone()
if result is not None:
print("价格:", result[0], "折扣:", result[1])
else:
print("该商品不存在!")
cursor.close()
conn.close()
# 添加商品功能
def add_product_0314():
product_name_0314 = input("请输入商品名称:")
product_price_0314 = float(input("请输入商品单价:"))
product_discount_0314 = float(input("请输入商品折扣(0.1-0.99之间):"))
conn = mysql.connector.connect(user='root', password='123456', database='market_0314')
cursor = conn.cursor()
sql = "INSERT INTO products_0314 (num_0314, name_0314, price_0314, discount_0314) VALUES (%s, %s, %s, %s)"
cursor.execute(sql, (generate_num_0314(), product_name_0314, product_price_0314, product_discount_0314))
conn.commit()
print("商品添加成功!")
cursor.close()
conn.close()
# 生成商品编号
def generate_num_0314():
conn = mysql.connector.connect(user='root', password='123456', database='market_0314')
cursor = conn.cursor()
sql = "SELECT MAX(num_0314) FROM products_0314"
cursor.execute(sql)
result = cursor.fetchone()[0]
cursor.close()
conn.close()
if result is None:
return "0001"
else:
return str(int(result) + 1).zfill(4)
# 修改商品价格和折扣功能
def modify_product_0314():
product_num_0314 = input("请输入商品编号:")
product_price_0314 = float(input("请输入新的商品单价:"))
product_discount_0314 = float(input("请输入新的商品折扣(0.1-0.99之间):"))
conn = mysql.connector.connect(user='root', password='123456', database='market_0314')
cursor = conn.cursor()
sql = "UPDATE products_0314 SET price_0314=%s, discount_0314=%s WHERE num_0314=%s"
cursor.execute(sql, (product_price_0314, product_discount_0314, product_num_0314))
conn.commit()
print("商品修改成功!")
cursor.close()
conn.close()
# 删除商品功能
def delete_product_0314():
product_num_0314 = input("请输入商品编号:")
conn = mysql.connector.connect(user='root', password='123456', database='market_0314')
cursor = conn.cursor()
sql = "DELETE FROM products_0314 WHERE num_0314=%s"
cursor.execute(sql, (product_num_0314,))
conn.commit()
print("商品删除成功!")
cursor.close()
conn.close()
# 查看所有订单功能
def show_all_orders_0314():
conn = mysql.connector.connect(user='root', password='123456', database='market_0314')
cursor = conn.cursor()
sql = "SELECT * FROM orders_0314"
cursor.execute(sql)
result = cursor.fetchall()
for r in result:
print(r)
cursor.close()
conn.close()
# 订单统计功能
def order_statistics_0314():
conn = mysql.connector.connect(user='root', password='123456', database='market_0314')
cursor = conn.cursor()
sql = "SELECT SUM(count_0314), SUM(amount_0314) FROM orders_0314"
cursor.execute(sql)
result = cursor.fetchone()
print("总销售额:", result[1], "货品数量:", result[0])
cursor.close()
conn.close()
# 商品结算功能
def product_settlement_0314():
product_num_0314 = input("请输入商品编号:")
product_count_0314 = int(input("请输入商品数量:"))
conn = mysql.connector.connect(user='root', password='123456', database='market_0314')
cursor = conn.cursor()
# 查询商品单价和折扣
sql = "SELECT price_0314, discount_0314 FROM products_0314 WHERE num_0314=%s"
cursor.execute(sql, (product_num_0314,))
result = cursor.fetchone()
if result is not None:
product_price_0314 = result[0]
product_discount_0314 = result[1]
# 计算商品金额
product_amount_0314 = product_price_0314 * product_discount_0314 * product_count_0314
# 添加订单
sql = "INSERT INTO orders_0314 (num_0314, count_0314, amount_0314) VALUES (%s, %s, %s)"
cursor.execute(sql, (product_num_0314, product_count_0314, product_amount_0314))
conn.commit()
print("商品结算成功!")
else:
print("该商品不存在!")
cursor.close()
conn.close()
# 主函数
def main_0314():
while True:
print("0.用户登录 1.查看所有产品信息 2.查找商品 3.添加商品 4.修改商品价格和折扣 5.删除商品 6.查看所有订单 7.订单统计 8.商品结算")
choice_0314 = input("请输入要执行的操作:")
if choice_0314 == "0":
login_0314()
elif choice_0314 == "1":
show_all_products_0314()
elif choice_0314 == "2":
search_product_0314()
elif choice_0314 == "3":
add_product_0314()
elif choice_0314 == "4":
modify_product_0314()
elif choice_0314 == "5":
delete_product_0314()
elif choice_0314 == "6":
show_all_orders_0314()
elif choice_0314 == "7":
order_statistics_0314()
elif choice_0314 == "8":
product_settlement_0314()
else:
print("输入有误,请重新输入!")
if __name__ == '__main__':
main_0314()
```
在代码中,我们使用了 MySQL 的 Python 客户端库 mysql-connector-python 来连接数据库,并通过 SQL 语句来实现各项业务。同时,我们也使用了 Navicat 来创建数据库和表。
阅读全文