Java SpringBoot+Vue3+MyBatis 小型企业客户关系管理系统系统源码|前后端分离+MySQL数据库

摘要

在当今数字化时代,企业客户关系管理(CRM)系统已成为提升企业竞争力的重要工具。随着中小型企业规模的扩大,客户数据的复杂性和多样性不断增加,传统的手工管理方式已无法满足高效、精准的客户管理需求。客户关系管理系统能够帮助企业整合客户信息、优化销售流程、提升客户满意度,从而实现业务增长。然而,许多小型企业由于预算和技术限制,难以部署大型商业CRM系统,亟需一套轻量级、低成本且功能完善的解决方案。本系统旨在为小型企业提供一套高效、易用的客户关系管理工具,通过信息化手段帮助企业实现客户数据的规范化管理,提升运营效率。关键词:客户关系管理、小型企业、信息化、数据整合、运营效率。

本系统采用前后端分离架构,前端基于Vue3框架开发,利用其响应式特性和组件化设计提升用户体验;后端采用SpringBoot框架,结合MyBatis实现数据持久化操作,确保系统的高效性和可扩展性。数据库选用MySQL,支持高并发访问和数据安全存储。系统功能模块包括客户信息管理、销售机会跟踪、合同管理、数据分析等,满足企业对客户全生命周期管理的需求。通过权限控制和数据加密技术,保障系统安全性。系统设计注重用户体验和操作便捷性,支持多端适配,为企业提供全方位的客户管理支持。关键词:SpringBoot、Vue3、MyBatis、前后端分离、MySQL、权限控制。

数据表

客户基础信息数据表

客户基础信息数据表用于存储企业客户的核心属性信息,包括客户名称、联系方式、行业分类等。创建时间是通过函数自动获取,客户编号是该表的主键,确保客户数据的唯一性和可追溯性。结构表如表3-1所示。

字段名数据类型是否为空描述
client_idBIGINT客户编号(主键)
client_nameVARCHAR(50)客户名称
contact_personVARCHAR(30)联系人姓名
contact_phoneVARCHAR(20)联系电话
industry_typeVARCHAR(30)行业分类
client_addressVARCHAR(100)客户地址
create_timeDATETIME创建时间
update_timeDATETIME更新时间
销售机会跟踪数据表

销售机会跟踪数据表用于记录企业与客户之间的销售进展,包括机会状态、预计成交金额等。机会编号是该表的主键,关联客户编号以实现数据联动。结构表如表3-2所示。

字段名数据类型是否为空描述
opportunity_idBIGINT机会编号(主键)
client_idBIGINT关联客户编号
opportunity_nameVARCHAR(50)机会名称
expected_amountDECIMAL(10,2)预计成交金额
progress_statusVARCHAR(20)进展状态
followup_dateDATE下次跟进日期
create_timeDATETIME创建时间
合同管理数据表

合同管理数据表用于存储企业与客户签订的合同信息,包括合同编号、签订日期、合同金额等。合同编号是该表的主键,关联客户编号以实现数据一致性。结构表如表3-3所示。

字段名数据类型是否为空描述
contract_idBIGINT合同编号(主键)
client_idBIGINT关联客户编号
contract_nameVARCHAR(50)合同名称
sign_dateDATE签订日期
contract_amountDECIMAL(10,2)合同金额
payment_statusVARCHAR(20)付款状态
create_timeDATETIME创建时间

博主介绍

🚀 技术导师 & 全栈架构师 专业背景:
深耕技术领域多年,全网累计影响力覆盖10W+开发者,荣获CSDN特邀作者、技术专家等多项认证,担任CSDN新星计划技术导师,专注Java企业级开发与小程序生态建设。
🎯 核心专栏矩阵 🔥 2025-2026届毕业设计智库

📱 微信小程序方向:精选100个前沿选题,紧跟市场趋势 ☕ Java企业级方向:汇聚500个实战选题,覆盖主流技术栈 💼
项目实战宝库:3000+精品案例库,涵盖完整开发链路

🎨 服务特色 ✨ 选题策略规划 - 结合行业趋势,量身定制技术路线 ✨ 架构设计指导 - 从零到一构建企业级应用 ✨ 论文写作辅导 -
技术文档专业化表达

详细视频演示

请联系我获取更详细的演示视频

系统介绍:

开源免费分享Java SpringBoot+Vue3+MyBatis 小型企业客户关系管理系统系统源码|前后端分离+MySQL数据库可提供说明文档 可以通过AIGC**技术包括:MySQL、VueJS、ElementUI、(Python或者Java或者.NET)等等功能如图所示。可以滴我获取详细的视频介绍





功能参考截图:

文档参考:

技术架构栈

🔧 后端技术:Spring Boot
Spring Boot 作为现代Java企业级开发的核心框架,以其**“约定优于配置”**的设计哲学重新定义了应用开发模式。 核心特性解析:

零配置启动:集成自动配置机制,大幅减少XML配置文件编写 嵌入式服务器:内置Tomcat/Jetty/Undertow,支持独立JAR包部署
生产就绪:集成Actuator监控组件,提供健康检查、指标收集等企业级特性 微服务友好:天然支持分布式架构,与Spring
Cloud生态无缝集成

开发优势:
通过Starter依赖体系和智能自动装配,开发者可将精力完全聚焦于业务逻辑实现,而非底层基础设施搭建。单一可执行JAR的部署模式极大简化了运维流程。

🎨 前端技术:Vue.js
Vue.js 以其渐进式框架设计和卓越的开发体验,成为现代前端开发的首选解决方案。 技术亮点:

响应式数据流:基于依赖追踪的响应式系统,实现高效的视图更新 组件化架构:单文件组件(SFC)设计,实现样式、逻辑、模板的完美封装
灵活的渐进式设计:可从简单的视图层库扩展至完整的SPA解决方案 丰富的生态系统:Vue Router、Vuex/Pinia、Vue
CLI等官方工具链完备

开发效率:
直观的模板语法结合强大的指令系统,让复杂的用户交互变得简洁明了。优秀的TypeScript支持和开发者工具,为大型项目提供可靠的开发保障。

核心代码

package com;importorg.mybatis.spring.annotation.MapperScan;importorg.springframework.boot.SpringApplication;importorg.springframework.boot.autoconfigure.SpringBootApplication;importorg.springframework.boot.builder.SpringApplicationBuilder;importorg.springframework.boot.web.servlet.support.SpringBootServletInitializer;@SpringBootApplication @MapperScan(basePackages={"com.dao"})publicclassSpringbootSchemaApplicationextends SpringBootServletInitializer{publicstaticvoidmain(String[]args){SpringApplication.run(SpringbootSchemaApplication.class,args);}@OverrideprotectedSpringApplicationBuilderconfigure(SpringApplicationBuilder applicationBuilder){returnapplicationBuilder.sources(SpringbootSchemaApplication.class);}}
package com.controller;importjava.math.BigDecimal;importjava.text.SimpleDateFormat;importjava.text.ParseException;importjava.util.ArrayList;importjava.util.Arrays;importjava.util.Calendar;importjava.util.Map;importjava.util.HashMap;importjava.util.Iterator;importjava.util.Date;importjava.util.List;importjavax.servlet.http.HttpServletRequest;importcom.utils.ValidatorUtils;importorg.apache.commons.lang3.StringUtils;importorg.springframework.beans.factory.annotation.Autowired;importorg.springframework.transaction.annotation.Transactional;importorg.springframework.format.annotation.DateTimeFormat;importorg.springframework.web.bind.annotation.PathVariable;importorg.springframework.web.bind.annotation.RequestBody;importorg.springframework.web.bind.annotation.RequestMapping;importorg.springframework.web.bind.annotation.RequestParam;importorg.springframework.web.bind.annotation.RestController;importcom.baomidou.mybatisplus.mapper.EntityWrapper;importcom.baomidou.mybatisplus.mapper.Wrapper;importcom.annotation.IgnoreAuth;importcom.entity.YonghuEntity;importcom.entity.view.YonghuView;importcom.service.YonghuService;importcom.service.TokenService;importcom.utils.PageUtils;importcom.utils.R;importcom.utils.MPUtil;importcom.utils.MapUtils;importcom.utils.CommonUtil;importjava.io.IOException;/** * 用户 * 后端接口 * @author * @email * @date 2024-04-24 17:59:31 */@RestController @RequestMapping("/yonghu")publicclassYonghuController{@AutowiredprivateYonghuService yonghuService;@AutowiredprivateTokenService tokenService;/** * 登录 */@IgnoreAuth @RequestMapping(value="/login")publicRlogin(String username,String password,String captcha,HttpServletRequest request){YonghuEntity u=yonghuService.selectOne(newEntityWrapper<YonghuEntity>().eq("yonghuzhanghao",username));if(u==null||!u.getMima().equals(password)){returnR.error("账号或密码不正确");}String token=tokenService.generateToken(u.getId(),username,"yonghu","用户");returnR.ok().put("token",token);}/** * 注册 */@IgnoreAuth @RequestMapping("/register")publicRregister(@RequestBody YonghuEntity yonghu){//ValidatorUtils.validateEntity(yonghu);YonghuEntity u=yonghuService.selectOne(newEntityWrapper<YonghuEntity>().eq("yonghuzhanghao",yonghu.getYonghuzhanghao()));if(u!=null){returnR.error("注册用户已存在");}Long uId=newDate().getTime();yonghu.setId(uId);yonghuService.insert(yonghu);returnR.ok();}/** * 退出 */@RequestMapping("/logout")publicRlogout(HttpServletRequest request){request.getSession().invalidate();returnR.ok("退出成功");}/** * 获取用户的session用户信息 */@RequestMapping("/session")publicRgetCurrUser(HttpServletRequest request){Long id=(Long)request.getSession().getAttribute("userId");YonghuEntity u=yonghuService.selectById(id);returnR.ok().put("data",u);}/** * 密码重置 */@IgnoreAuth @RequestMapping(value="/resetPass")publicRresetPass(String username,HttpServletRequest request){YonghuEntity u=yonghuService.selectOne(newEntityWrapper<YonghuEntity>().eq("yonghuzhanghao",username));if(u==null){returnR.error("账号不存在");}u.setMima("123456");yonghuService.updateById(u);returnR.ok("密码已重置为:123456");}/** * 后台列表 */@RequestMapping("/page")publicRpage(@RequestParam Map<String,Object>params,YonghuEntity yonghu,HttpServletRequest request){EntityWrapper<YonghuEntity>ew=newEntityWrapper<YonghuEntity>();PageUtils page=yonghuService.queryPage(params,MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew,yonghu),params),params));returnR.ok().put("data",page);}/** * 前台列表 */@IgnoreAuth @RequestMapping("/list")publicRlist(@RequestParam Map<String,Object>params,YonghuEntity yonghu,HttpServletRequest request){EntityWrapper<YonghuEntity>ew=newEntityWrapper<YonghuEntity>();PageUtils page=yonghuService.queryPage(params,MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew,yonghu),params),params));returnR.ok().put("data",page);}/** * 列表 */@RequestMapping("/lists")publicRlist(YonghuEntity yonghu){EntityWrapper<YonghuEntity>ew=newEntityWrapper<YonghuEntity>();ew.allEq(MPUtil.allEQMapPre(yonghu,"yonghu"));returnR.ok().put("data",yonghuService.selectListView(ew));}/** * 查询 */@RequestMapping("/query")publicRquery(YonghuEntity yonghu){EntityWrapper<YonghuEntity>ew=newEntityWrapper<YonghuEntity>();ew.allEq(MPUtil.allEQMapPre(yonghu,"yonghu"));YonghuView yonghuView=yonghuService.selectView(ew);returnR.ok("查询用户成功").put("data",yonghuView);}/** * 后台详情 */@RequestMapping("/info/{id}")publicRinfo(@PathVariable("id")Long id){YonghuEntity yonghu=yonghuService.selectById(id);returnR.ok().put("data",yonghu);}/** * 前台详情 */@IgnoreAuth @RequestMapping("/detail/{id}")publicRdetail(@PathVariable("id")Long id){YonghuEntity yonghu=yonghuService.selectById(id);returnR.ok().put("data",yonghu);}/** * 后台保存 */@RequestMapping("/save")publicRsave(@RequestBody YonghuEntity yonghu,HttpServletRequest request){if(yonghuService.selectCount(newEntityWrapper<YonghuEntity>().eq("yonghuzhanghao",yonghu.getYonghuzhanghao()))>0){returnR.error("用户账号已存在");}yonghu.setId(newDate().getTime()+newDouble(Math.floor(Math.random()*1000)).longValue());//ValidatorUtils.validateEntity(yonghu);YonghuEntity u=yonghuService.selectOne(newEntityWrapper<YonghuEntity>().eq("yonghuzhanghao",yonghu.getYonghuzhanghao()));if(u!=null){returnR.error("用户已存在");}yonghu.setId(newDate().getTime());yonghuService.insert(yonghu);returnR.ok();}/** * 前台保存 */@RequestMapping("/add")publicRadd(@RequestBody YonghuEntity yonghu,HttpServletRequest request){if(yonghuService.selectCount(newEntityWrapper<YonghuEntity>().eq("yonghuzhanghao",yonghu.getYonghuzhanghao()))>0){returnR.error("用户账号已存在");}yonghu.setId(newDate().getTime()+newDouble(Math.floor(Math.random()*1000)).longValue());//ValidatorUtils.validateEntity(yonghu);YonghuEntity u=yonghuService.selectOne(newEntityWrapper<YonghuEntity>().eq("yonghuzhanghao",yonghu.getYonghuzhanghao()));if(u!=null){returnR.error("用户已存在");}yonghu.setId(newDate().getTime());yonghuService.insert(yonghu);returnR.ok();}/** * 修改 */@RequestMapping("/update")@TransactionalpublicRupdate(@RequestBody YonghuEntity yonghu,HttpServletRequest request){//ValidatorUtils.validateEntity(yonghu);if(yonghuService.selectCount(newEntityWrapper<YonghuEntity>().ne("id",yonghu.getId()).eq("yonghuzhanghao",yonghu.getYonghuzhanghao()))>0){returnR.error("用户账号已存在");}yonghuService.updateById(yonghu);//全部更新returnR.ok();}/** * 删除 */@RequestMapping("/delete")publicRdelete(@RequestBody Long[]ids){yonghuService.deleteBatchIds(Arrays.asList(ids));returnR.ok();}}

文章下方名片联系我即可~

✌💗大家点赞、收藏、关注、评论啦 、查看✌💗
👇🏻获取联系方式👇🏻
精彩专栏推荐订阅:在下方专栏👇🏻

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1099020.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

联合仿真设置中元件库对照的常见问题指南

联合仿真中元件库映射的实战避坑指南&#xff1a;以Proteus为核心的跨平台协同设计你有没有遇到过这样的场景&#xff1f;在Altium里画好了一张复杂的原理图&#xff0c;信心满满地导出网表准备导入Proteus做联合仿真——结果一打开&#xff0c;满屏红叉&#xff1a;“Unknown …

【深析】 Docker Desktop 中的容器文件系统:OverlayFS vs Containerd Snapshots

引言 在使用 Docker Desktop 运行容器时&#xff0c;开发者经常会遇到各种复杂的文件系统路径。特别是当我们通过 -v 参数挂载本地目录时&#xff0c;Docker 会创建一系列复杂的存储结构。 本文将通过一个具体的 LocalAI 容器案例&#xff0c;深入解析 Docker Desktop 中两个不…

利用Miniconda-Python3.11镜像提升AI开发效率|Jupyter远程访问配置说明

利用 Miniconda-Python3.11 镜像与 Jupyter 远程访问提升 AI 开发效率 在当今 AI 项目快速迭代的背景下&#xff0c;一个稳定、可复现且易于协作的开发环境&#xff0c;往往比算法本身更能决定项目的成败。你是否曾遇到过这样的场景&#xff1a;本地训练好的模型换一台机器就报…

7-1 WPS JS宏 Object对象创建的几种方法

第7章Js对象在WPs中的应用7-1 WPS JS宏 对象创建的几种方法new Object:对象是一种复合值&#xff0c;汇聚多个值&#xff0c;可以按名称存储和获取这些值。对象是属性的无序集合&#xff0c;也就是说对象由多个属性组成&#xff0c;而每个属性又分属性名和属性值&#xff0c;也…

Keil C51与传感器接口编程:实战项目示例

Keil C51与传感器接口编程&#xff1a;从零构建一个环境监测系统你有没有遇到过这样的情况&#xff1f;手头有个小项目&#xff0c;预算有限&#xff0c;主控不能太贵&#xff0c;但又要稳定采集温度、光照和气体数据。这时候&#xff0c;8051单片机往往是个不错的选择——它便…

如何在Linux上使用Miniconda-Python3.11快速安装PyTorch GPU版本

如何在Linux上使用Miniconda-Python3.11快速安装PyTorch GPU版本从一个常见问题说起&#xff1a;为什么我的PyTorch不识别GPU&#xff1f; 你是不是也遇到过这种情况&#xff1a;辛辛苦苦写好了模型代码&#xff0c;满怀期待地运行训练脚本&#xff0c;结果 torch.cuda.is_avai…

STM32下载失败?排查JLink驱动设置的关键步骤

STM32下载失败&#xff1f;别急&#xff0c;先查这几点JLink配置陷阱 你有没有遇到过这样的场景&#xff1a;STM32开发板通电正常&#xff0c;J-Link也插上了&#xff0c;Keil或STM32CubeIDE里一点“Download”&#xff0c;结果弹出一个无情的提示——“ No target connected …

Conda环境命名规范:提高Miniconda-Python3.11项目的可维护性

Conda环境命名规范&#xff1a;提高Miniconda-Python3.11项目的可维护性 在现代AI研发和数据科学项目中&#xff0c;一个看似不起眼的细节——环境名称&#xff0c;往往成为团队协作效率的分水岭。你是否遇到过这样的场景&#xff1a;登录服务器后看到十几个名为 test、env1、p…

Miniconda-Python3.10镜像支持电子病历自然语言处理

Miniconda-Python3.10镜像支持电子病历自然语言处理 在医疗AI研发一线&#xff0c;你是否曾遇到这样的场景&#xff1a;团队成员本地环境各不相同&#xff0c;有人用Python 3.8&#xff0c;有人是3.9&#xff1b;transformers库版本不一导致模型加载失败&#xff1b;明明代码逻…

敏捷咨询机构案例分析:以标杆实践赋能企业数智化转型

在数字经济高速发展的今天&#xff0c;市场变化日益加速&#xff0c;企业面临着前所未有的竞争压力。敏捷管理作为一种灵活应对变化、提升组织效率的管理模式&#xff0c;已成为企业突破增长瓶颈、实现高质量发展的核心驱动力。而专业的敏捷咨询机构&#xff0c;正是帮助企业将…

Keil新建工程步骤通俗解释:适合初学者

手把手教你用Keil新建一个STM32工程&#xff1a;从零开始不踩坑你是不是也曾经打开Keil uVision&#xff0c;点了“新建工程”后一脸懵&#xff1f;弹出来的芯片列表密密麻麻&#xff0c;不知道选哪个&#xff1b;添加文件时又怕加错&#xff1b;编译一下全是红字报错……别急&…

基于Python的智慧大学生资助补助系统的设计与实现vue

目录已开发项目效果实现截图关于博主开发技术路线相关技术介绍核心代码参考示例结论源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;已开发项目效果实现截图 同行可拿货,招校园代理 ,本人源头供货商 基于Python的智慧大学生资助补助系统…

Conda clean清理缓存:释放Miniconda-Python3.11占用的磁盘空间

Conda clean清理缓存&#xff1a;释放Miniconda-Python3.11占用的磁盘空间 在现代数据科学与AI开发中&#xff0c;Python环境管理早已不再是“装个包就能跑”的简单事。随着项目迭代频繁、依赖庞杂&#xff0c;一个看似轻量的Miniconda安装&#xff0c;可能在几个月后悄然吞噬数…

GitHub Pages静态站点生成:用Miniconda-Python3.11运行MkDocs

GitHub Pages静态站点生成&#xff1a;用Miniconda-Python3.11运行MkDocs 在开源项目和团队协作日益频繁的今天&#xff0c;技术文档的质量与发布效率直接影响着项目的可维护性和用户上手速度。一个常见的痛点是&#xff1a;本地写好的文档&#xff0c;在CI流程中却因环境差异…

基于python的食力派网上订餐系统vue

目录已开发项目效果实现截图关于博主开发技术路线相关技术介绍核心代码参考示例结论源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;已开发项目效果实现截图 同行可拿货,招校园代理 ,本人源头供货商 基于python的食力派网上订餐系统vue …

Miniconda-Python3.10镜像支持AR/VR内容生成的预处理

Miniconda-Python3.10镜像支持AR/VR内容生成的预处理 在当今AR/VR应用加速落地的背景下&#xff0c;从游戏、教育到医疗仿真和工业数字孪生&#xff0c;高质量三维内容的生产正面临前所未有的挑战。这类开发工作高度依赖图像处理、姿态估计、空间重建以及深度学习模型训练等复杂…

ESP32连接阿里云MQTT:基于WiFi的通信层完整指南

ESP32连接阿里云MQTT&#xff1a;从零构建稳定、安全的物联网通信链路你有没有遇到过这样的场景&#xff1f;手头有一块ESP32&#xff0c;接好了温湿度传感器&#xff0c;也注册了阿里云IoT平台的产品和设备&#xff0c;但一到“怎么把数据发上去”这一步就卡住了。查资料发现要…

Java SpringBoot+Vue3+MyBatis 乡村养老服务管理系统系统源码|前后端分离+MySQL数据库

摘要 随着我国老龄化进程的加速&#xff0c;乡村地区的养老服务需求日益突出&#xff0c;传统的养老服务模式已难以满足现代社会的需求。乡村养老服务管理系统旨在通过信息化手段解决乡村地区养老服务资源分散、管理效率低下等问题。该系统整合了社区养老、居家养老等多种服务模…

使用Miniconda创建独立Python环境,高效管理CUDA与PyTorch版本

使用Miniconda创建独立Python环境&#xff0c;高效管理CUDA与PyTorch版本 在深度学习项目开发中&#xff0c;你是否经历过这样的场景&#xff1a;刚跑通一个基于 PyTorch 2.0 CUDA 11.8 的图像生成模型&#xff0c;转头要复现一篇使用 PyTorch 1.12 CUDA 11.3 的论文时&#…

6-13 WPS JS宏 Map实例2--拆分记录到表格

实例2--拆分记录到表格原数据结果&#xff1a;代码&#xff1a;function test(){var pah ThisWorkbook.Path "//";var arr Range("A2", Range("E999").End(xlUp)).Value();var titarr ["编号", "姓名", "部门"…