鲜花销售
目录
博主介绍:✌️大厂码农|毕设布道师,阿里云开发社区乘风者计划专家博主,CSDN平台Java领域优质创作者,专注于大学生项目实战开发、讲解和毕业答疑辅导。✌️
主要项目:小程序、SpringBoot、SSM、Vue、Html、Jsp、Nodejs等设计与开发。
🍅文末获取源码联系🍅
基于java+vue的鲜花销售系统设计与实现
一、前言
鲜花销售微信小程序具有鲜花销售信息管理功能的选择。鲜花销售微信小程序采用java技术,基于mysql开发,实现了首页、个人中心、用户管理、商家管理、鲜花信息管理、鲜花分类管理、管理员管理、系统管理等内容进行管理,本系统具有良好的兼容性和适应性,为用户提供更多的鲜花销售信息,也提供了良好的平台,从而提高系统的核心竞争力。
本在线花店利用MySQL数据库来存储信息,开发过程中采用了SSM+Vue框架,编程语言选用Java。整个系统遵循标准的软件开发流程,设计出用户友好的界面并提供了全面的功能。管理员在后台可执行鲜花种类管理、用户管理、鲜花管理和订单管理等功能。而普通用户则能查看鲜花详情,收藏喜欢的花卉,进行购买,发表商品评论,处理支付订单以及管理个人订单。
在线花店通过设定的有效性规则,能即时检测并修正错误信息,保证数据输入的精确性,从而提升了系统提供的数据可信度。这一机制大大降低了数据错误的可能性,为用户提供更为优质的服务体验。
**关键词:**线上花店;MySQL;SSM+Vue框架
二、系统功能设计

三、系统实现
1前台用户功能实现
对于任何网站,相应完成除了信息查看外,更多的操作,就必然要通过系统的身份审核,要通过相应的身份审核,就必然要进行注册,通过注册操作,可以获得合法的使用权限。在系统的注册页面,要根据系统的要求,如账号、密码等资料的填写及确认。另外,用户在注册时,系统处了进行必填项的非空检测外,还要对用户填入的信息进行数据库重复比对操作。如果,用户填入的用户名在数据库中已经存在,即已经被其他人注册,则系统会进行用户名重复的响应提示。在所有的登录注册都能够通过管理员审核后,表示用户是能够按照此账号名和密码对系统进行登录的。审核通过后首页会自动弹出注册成功的提示。以用户名为xxx,密码123456为例进行用户注册,如下图5-1所示:

图5-1用户注册界面
在设计系统的登录流程时,通常会从实用和有效性来考虑,即所设计的流程简单实用还要能够有效的屏蔽非法的登入系统,保护系统数据的安全。用户需要登录本系统时,需要在登录框中对应的输入个人的用户账号和密码,点击登录时,系统会自动接收到的帐密组合,在相应的存储数据表中检索,若检索能够得到结果,则表示该账密组合合法,则允许登录,系统会自动跳转页面,若检索无结果,则表示系统中不存在此账密组合用户,则给出错误提示,并停留登录页面。如下图5-2所示:

图5-2用户登录界面
主界面主要分为首页、商家、鲜花信息、论坛、公告信息轮播区,其原理就是在发出相应的查询申请时,系统会调用已设定好的MySQL数据库命令在指定的数据表中进行数据的检索,并且将检索得到的结果存储为数据集的形式,这样可以方便多个数据准确的绑定到GridView控件上,来完成属性和内容的对应和显示。通常的情况,系统会以DataKeyNames属性来绑定对应行的主键。这样的操作方式,可以很大限度上避免以后在数据操作时,发生错误。例如在以后的数据修改、删除操作。都需要进行数据的准确定位,通过DataKeyNames就可以避免定位出错,进而避免错误的删除或修改的发生。如下图5-3所示:

图5-3 系统主界面
用户点击鲜花信息页面的搜索栏输入鲜花名称、鲜花种类,进行查询,然后可以查看鲜花等信息,如果有需要可以添加到购物车、立即购买、收藏或者评论等操作,如图5-4所示:

图5-4鲜花信息页面
用户点击商家页面的搜索栏输入商家号、商家名称,进行查询,然后可以查看商家等信息,还可以点击下载等操作,如图5-5所示:

图5-5商家页面
购物车:用户将想要购买的鲜花加入购物车,加入购物车后可以增减数量、删除、点击购买,可一键清除失效鲜花,如图5-6所示:

图5-6购物车页面
在个人中心页面可以更新个人详细信息,还可以对我的发布、我的订单、我的地址、我的收藏进行详细操作;如图5-7所示:

图5-7个人中心界面
2后台管理员功能实现
后台管理员登录,在登录页面选择需要登录的角色,在正确输入用户名和密码后,点击登录操作;如图5-8所示。

图5-8后台管理员登录界面
管理员进入系统主页面,主要功能包括对用户、商家、鲜花种类、鲜花信息、论坛管理、系统管理、订单管理、个人资料等进行操作。管理员主页面如图5-9所示:

图5-9管理员主界面
管理员点击用户,在用户页面输入用户账号、用户姓名,可以查找,新增或移除用户信息,并根据需要对用户信息进行相对应的操作。如图5-10所示:

图5-10用户界面
管理员点击商家,在商家页面输入商家号、商家名称,可以查找,新增或移除商家信息,并根据需要对商家信息进行相对应的操作。如图5-11所示:

图5-11商家界面
管理员点击鲜花种类,在鲜花种类页面输入鲜花种类,可以查找,新增或移除鲜花种类,并根据需要对鲜花种类进行相对应的操作。如图5-12所示:

图5-12鲜花种类界面
管理员点击鲜花信息,在鲜花信息页面输入鲜花名称、商家名称、价格、最大价格,可以查找或移除鲜花信息,并根据需要对鲜花信息进行相对应的操作。如图5-13所示:

图5-13鲜花信息界面
管理员点击论坛管理,在论坛管理页面输入帖子标题,可以查找或移除论坛信息,并根据需要对论坛信息进行相对应的操作。如图5-14所示:

图5-14论坛管理界面
管理员点击系统管理,在系统管理页面中包括轮播图管理、公告信息、公告信息分类、在线客服模块,可以查找或新增、移除系统信息,并根据需要对系统信息进行相对应的操作。如图5-15所示:

图5-15系统管理界面
3后台商家功能实现
后台商家注册、登录,在注册、登录页面正确输入用户名和密码等信息后,点击注册或者登录操作;如图5-16所示。


图5-16后台商家注册、商家登录界面
商家进入系统主页面,主要功能包括对鲜花信息、订单管理、个人资料等进行操作。商家主页面如图5-17所示:

图5-17商家主界面
商家点击鲜花信息,在鲜花信息页面输入鲜花名称、商家名称、价格、最大价格,可以查找,新增或移除鲜花信息,并根据需要对鲜花信息进行相对应的操作。如图5-18所示:

图5-18鲜花信息界面
四、数据库设计
1、实体ER图
鲜花销售管理系统的E-R图如下图所示:
鲜花信息实体图如图4-1所示:

图4-1鲜花信息实体图
购物车实体图如图4-2所示:

图4-2购物车实体图
2、具体的表设计如下所示:
表:鲜花信息评论表
|----------|-----------|------------|-------|----|-------------------|
| 字段名称 | 类型 | 长度 | 字段说明 | 主键 | 默认值 |
| id | bigint | | 主键 | 主键 | |
| addtime | timestamp | | 创建时间 | | CURRENT_TIMESTAMP |
| refid | bigint | | 关联表id | | |
| userid | bigint | | 用户id | | |
| nickname | varchar | 200 | 用户名 | | |
| content | longtext | 4294967295 | 评论内容 | | |
| reply | longtext | 4294967295 | 回复内容 | | |
表:鲜花信息
|------------------|-----------|------------|--------|----|-------------------|
| 字段名称 | 类型 | 长度 | 字段说明 | 主键 | 默认值 |
| id | bigint | | 主键 | 主键 | |
| addtime | timestamp | | 创建时间 | | CURRENT_TIMESTAMP |
| xianhuamingcheng | varchar | 200 | 鲜花名称 | | |
| xianhualeixing | varchar | 200 | 鲜花类型 | | |
| chandi | varchar | 200 | 产地 | | |
| xiangguanhuayu | varchar | 200 | 相关花语 | | |
| zengsongduixiang | varchar | 200 | 赠送对象 | | |
| shipinxinxi | varchar | 200 | 视频信息 | | |
| xianhuajieshao | longtext | 4294967295 | 鲜花介绍 | | |
| xianhuatupian | varchar | 200 | 鲜花图片 | | |
| shangpubianhao | varchar | 200 | 商铺编号 | | |
| shangpumingcheng | varchar | 200 | 商铺名称 | | |
| lianxidianhua | varchar | 200 | 联系电话 | | |
| thumbsupnum | int | | 赞 | | 0 |
| crazilynum | int | | 踩 | | 0 |
| clicktime | datetime | | 最近点击时间 | | |
| clicknum | int | | 点击次数 | | 0 |
| price | float | | 价格 | | |
| vipprice | float | | 会员价 | | -1 |
表:购物车表
|----------------|-----------|-----|------|----|-------------------|
| 字段名称 | 类型 | 长度 | 字段说明 | 主键 | 默认值 |
| id | bigint | | 主键 | 主键 | |
| addtime | timestamp | | 创建时间 | | CURRENT_TIMESTAMP |
| tablename | varchar | 200 | 商品表名 | | xianhuaxinxi |
| userid | bigint | | 用户id | | |
| goodid | bigint | | 商品id | | |
| goodname | varchar | 200 | 商品名称 | | |
| picture | varchar | 200 | 图片 | | |
| buynumber | int | | 购买数量 | | |
| price | float | | 单价 | | |
| discountprice | float | | 会员价 | | |
| shangpubianhao | varchar | 200 | 商户名称 | | |
表:鲜花分类
|---------|-----------|-----|------|----|-------------------|
| 字段名称 | 类型 | 长度 | 字段说明 | 主键 | 默认值 |
| id | bigint | | 主键 | 主键 | |
| addtime | timestamp | | 创建时间 | | CURRENT_TIMESTAMP |
| leixing | varchar | 200 | 类型 | | |
表:地址
|-----------|-----------|-----|---------------|----|-------------------|
| 字段名称 | 类型 | 长度 | 字段说明 | 主键 | 默认值 |
| id | bigint | | 主键 | 主键 | |
| addtime | timestamp | | 创建时间 | | CURRENT_TIMESTAMP |
| userid | bigint | | 用户id | | |
| address | varchar | 200 | 地址 | | |
| name | varchar | 200 | 收货人 | | |
| phone | varchar | 200 | 电话 | | |
| isdefault | varchar | 200 | 是否默认地址[是/否] | | |
五、核心代码
java
package com.service.impl;
import org.springframework.stereotype.Service;
import java.util.Map;
import java.util.List;
import com.baomidou.mybatisplus.mapper.Wrapper;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.baomidou.mybatisplus.plugins.Page;
import com.baomidou.mybatisplus.service.impl.ServiceImpl;
import com.utils.PageUtils;
import com.utils.Query;
import com.dao.XianhuafenleiDao;
import com.entity.XianhuafenleiEntity;
import com.service.XianhuafenleiService;
import com.entity.vo.XianhuafenleiVO;
import com.entity.view.XianhuafenleiView;
@Service("xianhuafenleiService")
public class XianhuafenleiServiceImpl extends ServiceImpl<XianhuafenleiDao, XianhuafenleiEntity> implements XianhuafenleiService {
@Override
public PageUtils queryPage(Map<String, Object> params) {
Page<XianhuafenleiEntity> page = this.selectPage(
new Query<XianhuafenleiEntity>(params).getPage(),
new EntityWrapper<XianhuafenleiEntity>()
);
return new PageUtils(page);
}
@Override
public PageUtils queryPage(Map<String, Object> params, Wrapper<XianhuafenleiEntity> wrapper) {
Page<XianhuafenleiView> page =new Query<XianhuafenleiView>(params).getPage();
page.setRecords(baseMapper.selectListView(page,wrapper));
PageUtils pageUtil = new PageUtils(page);
return pageUtil;
}
@Override
public List<XianhuafenleiVO> selectListVO(Wrapper<XianhuafenleiEntity> wrapper) {
return baseMapper.selectListVO(wrapper);
}
@Override
public XianhuafenleiVO selectVO(Wrapper<XianhuafenleiEntity> wrapper) {
return baseMapper.selectVO(wrapper);
}
@Override
public List<XianhuafenleiView> selectListView(Wrapper<XianhuafenleiEntity> wrapper) {
return baseMapper.selectListView(wrapper);
}
@Override
public XianhuafenleiView selectView(Wrapper<XianhuafenleiEntity> wrapper) {
return baseMapper.selectView(wrapper);
}
}
六、论文参考



七、最新计算机毕设选题推荐
八、源码获取:
大家点赞、收藏、关注、评论 啦 、👇🏻获取联系方式在文章末尾👇🏻