零售药店管理系统 【Python+数据库】

1 背景介绍

结合本学期所学的Python和数据库完成一个零售药店管理系统

2 问题定义

零售药店管理系统通过录入零售药品信息、员工信息、客户信息、供应商信息、库房信息和管理员登录信息,实现对药品、员工、客户、供应商、库房和管理员信息的增加、删除、修改和查找四项基本功能,同时能对药店的销售流水、进货信息等记录,并实现数据分析可视化功能,以此决定营业主方向等其他一些功能。

3 需求分析

3.1功能需求

3.1.1基本功能
1.基础信息管理:药品信息、员工信息、客户信息、供应商信息等。
2.进货管理:入库登记、入库登记查询、入库报表等。
3.库房管理:库存查询、库存盘点、库存报表等。
4.销售管理:销售登记、销售报表及相应的查询等。
5.系统维护:用户登录管理、系统设置和修改密码。

3.2数据库需求

3.2.1需要存储数据信息

实体
1.药品(药品编号,药品名称,药品价格,供应商,药品数量,所在库房);
2.员工(员工编号,员工姓名,性别,年龄,电话);
3.客户(客户VIP号,姓名,性别,年龄,电话,住址);
4.供应商(供货商编号,供应商名称,供应药品名称,供应商电话,供应商地址);
5.库房(库房编号,名称,地址);
6.管理员登录(序号,用户号,密码);

功能
7.销售流水(销售流水号,销售员工姓名,销售药品编号,销售药品名称,销售日期,销售数量,销售单价,销售总金额);
8.进货(进货日期,库房编号,库房名称,药品名称,药品进价,进货数量);
9.库存(库房名称,药品编号,药品名称,库存量);放入零售药品信息里一起管理
10.登录(用户名,密码);

3.2.2分别对应数据库里的二维表信息

1.Drug(Drugnum,Drugname,Drugprice,DrugSup,Drugnumber,Drughouse);
2.Staff(Staffnum,Staffname,Ssex,Sage,Sphone);
3.Consumers(Cnum,Cname,Csex,Cage,Cphone,Caddress);
4.Suppliers(Supnum,Supname,Supdrug,Supphone,Supaddress);
5.House(Housenum,Housename,Houseaddress);
6.Login(num,name,password);
7.Sale(Salenum,Staffname,Drugnum,Drugname,Saledate,Salenumber,Saleprice,Saletotal);
8.Loadin(Datenum,Housenum,Housename,Drugname,Drugpricein,Drugsum);

4 数据库分析

4.1数据字典

4.2数据流图

4.3业务流程图

5 系统设计

5.1数据库设计

5.1.1概念模型设计





6 功能系统模块设计

6.1登录功能
伪代码:
1.创建登录窗口;
2.添加“用户名”和“密码”标签以及两个多行文本框;
3.添加“登录”和“退出”两个按钮;
4.连接数据库,检查用户名和密码;
5.登录失败,报出warning警告;
流程图:

import tkinter as tk
from tkinter import messagebox
import pymysql
from MainPage import MainPage
from PIL import Image, ImageTkdef Landing():root=tk.Tk()root.geometry('820x400')root.title('药店员工登录界面')image_file = Image.open("D:\\百度下载\\12.jpg")photo = ImageTk.PhotoImage(image_file)tk.Label(root,image=photo).pack()username = tk.StringVar()password = tk.StringVar()Lable1 = tk.Label(root, text='账号:', font=('Verdana', 13), fg='black')Lable1.place(relx=0.4, rely=0.4)entry1 = tk.Entry(root, textvariable=username,width=15, font=('Verdana', 10, 'bold', 'italic'))entry1.place(relx=0.5, rely=0.4)Lable2 = tk.Label(root, text='密码:', font=('Verdana', 13), fg='black')Lable2.place(relx=0.4, rely=0.5)entry2 = tk.Entry(root, textvariable=password,show='*',width=15, font=('Verdana', 10))entry2.place(relx=0.5, rely=0.5)def Login():db = pymysql.connect(host="localhost", user="root", passwd="12345", db="database")cur = db.cursor()sql = f"select * from Login where name='{username}' and password='{password}'"cur.execute(sql)db.commit()data = cur.fetchall()if data != "":root.destroy()MainPage()else:messagebox.showwarning(title='警告', message='登陆失败!请检查账号密码输入是否正确!')tk.Button(root, text="登录", command=Login).place(relx=0.4,rely=0.7)tk.Button(root, text='退出', command=quit).place(relx=0.55,rely=0.7)root.mainloop()if __name__=='__main__':Landing()

运行效果图

6.2基本操作功能
伪代码:
1.创建主界面窗体;
2.添加“基本操作”菜单;
3.为“基本操作”菜单添加子菜单“零售药品信息”、“员工信息”、“客户信息”、“供应商信息”和“库房信息”;
4.将子菜单“零售药品信息”、“员工信息”、“客户信息”、“供应商信息”和“库房信息”连接数据库,并提供相应的增/删/改/查操作;
流程图:

import tkinter as tk
import Druginfo
import About
import Consumers
import House
import Sale
import Staffinfo
import Suppliersinfo
import Loadin
import Logininfo
import Analyse
from PIL import Image, ImageTk
def MainPage():top=tk.Tk()top.title('零售药店管理系统  v0.0.1')top.geometry('820x400')image_file = Image.open("D:\\百度下载\\11.jpg")photo = ImageTk.PhotoImage(image_file)tk.Label(top,image=photo).pack()menubar=tk.Menu(top)menubar1=tk.Menu(menubar)menubar2=tk.Menu(menubar)menubar3=tk.Menu(menubar)menubar4= tk.Menu(menubar)menubar5=tk.Menu(menubar)menubar.add_cascade(label='基本操作',menu=menubar1)menubar1.add_command(label='零售药品信息',command=Druginfo.Drug)menubar1.add_separator()menubar1.add_command(label='员工信息', command=Staffinfo.Staff)menubar1.add_separator()menubar1.add_command(label='客户信息', command=Consumers.Consumers)menubar1.add_separator()menubar1.add_command(label='供应商信息', command=Suppliersinfo.Suppliers)menubar1.add_separator()menubar1.add_command(label='库房信息', command=House.House)menubar.add_cascade(label='系统管理', menu=menubar2)menubar2.add_command(label='登录管理',command=Logininfo.Login)menubar.add_cascade(label='财务流通',menu=menubar3)menubar3.add_command(label='销售记录',command=Sale.Sale)menubar3.add_separator()menubar3.add_command(label='进货记录', command=Loadin.Loadin)menubar.add_cascade(label='数据可视化',menu=menubar4)menubar4.add_command(label='药品——价格分析',command=Analyse.analyse1)menubar4.add_separator()menubar4.add_command(label='药品入库分析',command=Analyse.analyse2)menubar4.add_separator()menubar4.add_command(label='进货数量分析',command=Analyse.analyse3)menubar4.add_separator()menubar4.add_command(label='进货药品价格分析',command=Analyse.analyse4)menubar4.add_separator()menubar4.add_command(label='药品销量分析',command=Analyse.analyse5)menubar.add_cascade(label='关于', menu=menubar5)menubar5.add_command(label='帮助', command=About.About)top['menu']=menubartop.mainloop()
if __name__=='__main__':MainPage()

运行效果图





有需要完整代码的同学,希望点赞+收藏,再留言,邮箱地址切勿留错!!!

零售药店管理系统 Python+MySQL数据库相关推荐

  1. 药一点医药软件供应商—零售药店管理系统

    药一点医药软件供应商-零售药店管理系统 产品介绍 1.1.本系统是一款专门服务于药房.医药管理机构等企业开发的专业医药管理软件,100%通过GSP认证. 1.2.系统是集进.销.存.财务以及会员一体化 ...

  2. Python MySQL数据库的连接以及基本操作

    Python MySQL数据库的连接以及基本操作 一.数据库的连接 1.直接连接 2.连接池连接 二. 数据库的基本操作 1.执行函数 2.创建数据表 3.删除表 4.插入函数 6.删除函数 7.状态 ...

  3. Python项目:学生管理系统连接MySQL数据库(增删改查、排序、统计、显示所有信息)

    文章目录 一程序功能(Function) 1. 功能概述 2. 思维导图 二.开始实践 战前准备 定义学生管理系统菜单 定义主函数 1.录入学生信息 2.查找学生信息 3.删除学生信息 4.修改学生信 ...

  4. 基于Python+Mysql数据库的图书管理系统课设

    开发环境说明: windows 11 专业版 python 3.7 (所用模块pymysql) PyCharm 专业版 MYSQL 8.0 需要源代码看作者主页联系方式,或看评论区加,或私信 程序问题 ...

  5. 期末课程设计——基于Python+MySQL数据库的学生管理系统(附源代码)

    一.        设计题目 二.        开发环境 三.        设计思想 四.        系统结构 五.        系统使用说明与数据测试: 1.     启动Mysql数据库 ...

  6. Python Mysql 数据库操作

    2019独角兽企业重金招聘Python工程师标准>>> 本文实例讲述了python中MySQLdb模块用法.分享给大家供大家参考.具体用法分析如下: MySQLdb其实有点像php或 ...

  7. Python MySQL数据库交互

    引言 本文介绍在 Python 中如何与 MySQL 数据库交互 利用 PyMySQL 数据库驱动,实现 MySQL 数据库的增删改查及事务处理 MySQL 简介 MySQL是一个关系型数据库管理系统 ...

  8. java学生信息管理系统(GUI+mysql数据库)

    java学生信息管理系统+GUI界面布局+mysql数据库 代码已经更新!,重新设计了UI界面,代码之间的逻辑更加清晰 新的代码不需要手动建立数据库和表,全部由程序自动执行 用户名和密码为你数据库的用 ...

  9. 学籍管理系统+python mysql+hash加密

    文章目录 高校学籍管理系统 一.数据库课程设计要求与目的 二.需求分析 2.1 需求分析 2.2 系统功能模块图 2.3数据字典 2.4 事务 2.5 触发器: 三.概念结构设计 3. 1 实体与联系 ...

最新文章

  1. 轻松自动化---selenium-webdriver(python) (六)
  2. Stanford UFLDL教程 逻辑回归的向量化实现样例
  3. 秀!Pandas 也能爬虫!
  4. SQL Server【二】单表查询
  5. mysql 日期分隔符_sql中的日期处理
  6. parse data from Nacos error
  7. 显示lib包_Java 添加、删除、移动、隐藏/显示Excel工作表
  8. 新闻丨智链万源受邀参加世界动物福利科学大会
  9. CSS学习21:fixed(固定定位)
  10. 深入分析Java中的length和length()
  11. 电脑桌面计算机图标下不显示文字,为什么电脑桌面上的图标文下面没有显文字...
  12. ReactNative基础(六)使用react-navigation实现页面导航布局效果(TabNavigator)
  13. 使用emitter的坑,
  14. vue 获取当前路由地址
  15. apple pay 技术_如何在Apple Watch上设置和使用Apple Pay
  16. stm32C8t6 通用定时器输出PWM+定时中断控制板载LED
  17. html5 游戏广告 sdk,帷千动媒SDK 3.0发布 基于HTML5富媒体广告
  18. JavaSE进阶318-331 构造方法习题
  19. 撕掉代工标签,能否迎来芯片市场的“权力转移”?
  20. 读稻盛和夫《活法》-现代人的修行之路

热门文章

  1. 高仿富途牛牛-组件化(三)-界面美化
  2. SAP知识精解-物料需求计划MRP-概览
  3. asp.net校园新闻管理系统毕业设计(附源码、运行环境)
  4. USB2.0 HUB
  5. 护卫神php套件快速搭建本地IIS网站,及解决80端口被封、动态IP甚至无公网IP
  6. 张国宝:东北地区经济社会发展加快
  7. 加密货币市值、股市市值、房地产价值
  8. 机器人课程反馈中如何面对批评和负面消息
  9. 让你思维洞开的5个头脑风暴工具
  10. 211计算机考研到985难度,这份考研难度排行榜亮了,很多人不知道,这几所211竟比985还难考...