# 程序设计报告
qq:773323518
## 题目
超市进销存管理系统
## 代码及版本管理地址
[gitee码云版本地址(点击跳转)](https://gitee.com/wu_wen_yi/supermarket-inventory-management-system)
## 问题描述
本项目学生需要通过此项目完成项目数据库设计,信息系统开发等。
### 系统介绍
系统分为两个权限部分:管理员用户登录模块,普通用户登陆模块。管理员用户登录模块包括:供应商管理,员工管理,商品管理,会员管理,采购管理。普通用户登陆模块包括:个人信息,商品信息,采购信息。本项目实现以下功能:
### 管理员用户登录模块:
#### 供应商管理
批量录入供应商数据,手动输入供应商编号,供应商名称,供应商简称,地址,公司电话,邮件,联系人,联系人电话,备注。
查询并列出表中所有的供应商信息。
修改指定供应商的信息。
删除指定供应商数据。
#### 商品管理
批量录入商品数据,手动输入商品编号,商品名称,商品单价,供应商编号,商品简介,备注等。
查询并列出所有商品信息。
修改制定商品的商品信息。
删除指定商品数据。
#### 员工管理
批量录入员工数据,手动输入员工编号,员工姓名,员工密码,员工级别,员工电话,员工工资,备注等。
查询并列出所有员工信息。
修改指定员工信息。
删除指定员工数据。
#### 采购管理
录入采购主表数据,手动输入采购清单号,员工编号(外码),采购数量,采购总价,采购时间,备注。
录入采购明细数据,手动输入采购明细号,采购清单号(外码),商品编号(外码),采购数量,商品单价,商品总价,备注。
查询并列出所有采购主表和采购明细信息。
修改指定采购主表信息和采购明细信息。
删除指定采购主表信息和采购明细信息。
### 普通用户登陆模块:
#### 员工查询
查询自己的员工信息。
#### 商品查询
查询所有商品信息。
#### 采购查询
查询所有的采购信息。
## 软件设计
### 软件架构图
![软件架构图](https://images.gitee.com/uploads/images/2021/0620/104705_3051979e_6512114.png "WEB开发技术架构图.png")
### 技术栈
- 视图层:vue3.0
- 控制层:gin+gorm
- 持久化:postgresql+redis
### 持久化
#### 数据库概念模型设计(ER图)
![ER](https://images.gitee.com/uploads/images/2021/0620/104730_4125dced_6512114.png "ER.png")
#### PostgreSQL数据库物理模型设计
![模型](https://images.gitee.com/uploads/images/2021/0620/104838_1734bd16_6512114.png "模型.png")
#### PostgreSQL
##### 触发器
###### 删除goods实体后触发
```sql
CREATE OR REPLACE FUNCTION "public"."del_goods_func"()
RETURNS "pg_catalog"."trigger" AS $BODY$
BEGIN
IF NEW.is_del = TRUE
THEN
UPDATE erp_purchase_details SET is_del = TRUE where purchase_details_goods = NEW.goods_id;
END IF;
RETURN NEW;
END;
$BODY$
LANGUAGE plpgsql VOLATILE
COST 100
```
```sql
CREATE TRIGGER "del_goods_trigger" AFTER UPDATE OF "is_del" ON "public"."erp_goods"
FOR EACH ROW
EXECUTE PROCEDURE "public"."del_goods_func"();
```
###### 删除staff实体后触发
```sql
CREATE OR REPLACE FUNCTION "public"."del_staff_func"()
RETURNS "pg_catalog"."trigger" AS $BODY$
BEGIN
IF NEW.is_del = TRUE
THEN
UPDATE erp_purchase_list SET is_del = TRUE where purchase_list_staff = NEW.staff_id;
END IF;
RETURN NEW;
END;
$BODY$
LANGUAGE plpgsql VOLATILE
COST 100
```
```sql
CREATE TRIGGER "del_staff_trigger" AFTER UPDATE OF "is_del" ON "public"."erp_staff"
FOR EACH ROW
EXECUTE PROCEDURE "public"."del_staff_func"();
```
###### 删除supplier实体后触发
```sql
CREATE OR REPLACE FUNCTION "public"."del_supplier_func"()
RETURNS "pg_catalog"."trigger" AS $BODY$
BEGIN
IF NEW.is_del = TRUE
THEN
UPDATE erp_goods SET is_del = TRUE where goods_supplier = NEW.supplier_id;
END IF;
RETURN NEW;
END;
$BODY$
LANGUAGE plpgsql VOLATILE
COST 100
```
```sql
CREATE TRIGGER "del_supplier_trigger" AFTER UPDATE OF "is_del" ON "public"."erp_supplier"
FOR EACH ROW
EXECUTE PROCEDURE "public"."del_supplier_func"();
```
###### 删除purchase_list实体后触发
```sql
CREATE OR REPLACE FUNCTION "public"."del_purchase_list_func"()
RETURNS "pg_catalog"."trigger" AS $BODY$
BEGIN
IF NEW.is_del = TRUE
THEN
UPDATE erp_purchase_details SET is_del = TRUE where purchase_details_list = NEW.purchase_list_id;
END IF;
RETURN NEW;
END;
$BODY$
LANGUAGE plpgsql VOLATILE
COST 100
```
```sql
CREATE TRIGGER "del_purchase_list_trigger" AFTER UPDATE OF "is_del" ON "public"."erp_purchase_list"
FOR EACH ROW
EXECUTE PROCEDURE "public"."del_purchase_list_func"();
```
###### 插入purchase_details实体后触发
```sql
CREATE OR REPLACE FUNCTION "public"."insert_details_func"()
RETURNS "pg_catalog"."trigger" AS $BODY$
BEGIN
UPDATE erp_purchase_list SET purchase_list_number = purchase_list_number+NEW.purchase_details_number where purchase_list_id = NEW.purchase_details_list;
UPDATE erp_purchase_list SET purchase_list_price = purchase_list_price+NEW.purchase_details_price where purchase_list_id = NEW.purchase_details_list;
RETURN NEW;
END;
$BODY$
LANGUAGE plpgsql VOLATILE
COST 100
```
```sql
CREATE TRIGGER "insert_detail_trigger" AFTER INSERT ON "public"."erp_purchase_details"
FOR EACH ROW
EXECUTE PROCEDURE "public"."insert_details_func"();
```
###### 更新purchase_details实体后触发
```sql
CREATE OR REPLACE FUNCTION "public"."update_details_func"()
RETURNS "pg_catalog"."trigger" AS $BODY$
BEGIN
IF NEW.is_del = TRUE
THEN
UPDATE erp_purchase_list SET purchase_list_number = purchase_list_number-OLD.purchase_details_number where purchase_list_id = NEW.purchase_details_list;
UPDATE erp_purchase_list SET purchase_list_price = purchase_list_price-OLD.purchase_details_price where purchase_list_id = NEW.purchase_details_list;
ELSE
UPDATE erp_purchase_list SET purchase_list_number = purchase_list_number+(NEW.purchase_details_number-OLD.purchase_details_number) where purchase_list_id = NEW.purchase_details_list;
UPDATE erp_purchase_list SET purchase_list_price = purchase_list_price+(NEW.purchase_details_price-OLD.purchase_details_price) where purchase_list_id = NEW.purchase_details_list;
END IF;
RETURN NEW;
END;
$BODY$
LANGUAGE plpgsql VOLATILE
COST 100
```
```sql
CREATE TRIGGER "update_detail_trigger" AFTER UPDATE ON "public"."erp_purchase_details"
FOR EACH ROW
EXECUTE PROCEDURE "public"."update_details_func"();
```
##### 索引
###### 对goods实体的goods_name字段建立唯一索引
```sql
CREATE UNIQUE INDEX "unip_name" ON "public"."erp_goods" USING btree (
"goods_name" COLLATE "pg_catalog"."default" "pg_catalog"."text_ops" ASC NULLS LAST
);
```
###### 对staff实体的staff_ name字段建立唯一索引
```sql
CREATE UNIQUE INDEX "uniq_staff_name" ON "public"."erp_staff" USING btree (
"staff_name" COLLATE "pg_catalog"."default" "pg_catalog"."text_ops" ASC NULLS LAST
);
```
###### 对supplier实体的supplier_name字段建立唯一索引
```sql
CREATE UNIQUE INDEX "uniq_supplier_name" ON "public"."erp_supplier" USING btree (
"supplier_name" COLLATE "pg_catalog"."default" "pg_catalog"."text_ops" ASC NULLS LAST
);
```
###### 对purchase_details实体的details_list和details_goods两字段建立联合索引
按照最左优先原则,将details_list字段放在左边
```sql
CREATE INDEX "list_goods_btree" ON "public"."erp_purchase_details" USING btree (
"purchase_details_list" "pg_catalog"."int8_ops" ASC NULLS LAST,
"purchase_details_goods" "pg_catalog"."int8_ops" ASC NULLS LAST
);
```
#### Redis
用于缓存postgresql中的sys_menu实体
![输入图片
Python代码大全
- 粉丝: 2870
- 资源: 686
最新资源
- 三菱FX3U 步进电机算FB块 FB块的使用可以使程序模块化简单化,进而提高了程序的稳定性和可移植性 此例中使用FB块,可以实现步进电机的算,已知距离求得脉冲数,已知速度可以求得频率 程序中包含
- 双向隔离DCDC仿真simulink
- 基于PSO粒子群PID控制器参数整定粒子群PID psopid 基于粒子群算法整定PID控制器,实现PID控制器参数的自整定(PSO-PID) matlab编写,源码注释详细具体如图,评价指标详
- 3567954014871001-进程的概念.zip
- 伺服电机、步进电机通用的S曲线及梯形加减速控制源码,十分经典,有中文注释及实现原理说明 系前期从某高手卖家处高价购得(技术源头实为国外专业公司) 本人已经在多个自动化控制系统中采用,为摊低成本故低
- DSP28335的Svpwm处理器在环仿真(matlab simulink)
- cruise模型,增程汽车仿真模型,恒功率控制 关于模型: 1.模型是个base模型,基于cruise simulink联合仿真,主要实现恒功率控制以及电制动优先的能量回收策略,主要供学习使用
- Polarion表结构
- ssm中小型企业财务管理系统+jsp.zip
- ssm珠宝首饰交易平台开发+jsp.zip
- ssm助学贷款+jsp.zip
- ssm职工健康每日申报系统设计+vue.zip
- ssm在线作业管理系统的设计与实现+vue.zip
- ssm中国咖啡文化宣传网站的设计与实现+vue.zip
- FIFO verilogIP 包括深度为1的fifo 包括普通同步FIFO和异步FIFO,均为first word fall through模式,同步fifo三种写法,异步fifo三种写法,可参
- ssm在线医疗服务系统+jsp.zip
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈