Java项目:CRM客户关系管理系统(Spring+SpringMVC+MyBatis + maven)(三)

本文涉及的产品
私网连接 PrivateLink,5万GB流量 1.5万小时实例时长
简介: Java项目:CRM客户关系管理系统(Spring+SpringMVC+MyBatis + maven)(三)

4. 联系人管理


4.1 联系人与客户关系分析


客户:指的是有很多员工的公司、组织、企业或类似机构。


例如:传智学院


联系人:与某公司(客户)进行对接时,所需要找该公司具体的员工。


例如:教学-梁老师、就业-刘老师、后勤-唐老师


根据分析,在CRM系统中,客户和联系人的关系是一对多,一个公司有多个对接人。


4.2 查询所有联系人

4.2.1 查询所有

需求:


步骤:


步骤1:入口


步骤2:编写LinkManController


步骤3:编写LinkManService 接口、实现类


步骤4:修改 linkman/list.jsp 展示数据


步骤1:入口


步骤2:编写LinkManController


package com.czxy.crm.controller;
import com.czxy.crm.domain.LinkMan;
import com.czxy.crm.service.LinkManService;
import com.czxy.crm.vo.LinkManVo;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import javax.annotation.Resource;
import java.util.List;
/**
 * @author 桐叔
 * @email liangtong@itcast.cn
 */
@Controller
@RequestMapping("/linkman")
public class LinkManController {
    @Resource
    private LinkManService linkManService;
    @RequestMapping("/findAll")
    public String findAll(Model model){
        // 查询所有
        List<LinkMan> linkManList = linkManService.findAll();
        model.addAttribute("linkManList", linkManList);
        return "linkman/list";
    }
}

步骤3:编写LinkManService 接口、实现类


接口


package com.czxy.crm.service;
import com.czxy.crm.domain.LinkMan;
import java.util.List;
/**
 * @author 桐叔
 * @email liangtong@itcast.cn
 */
public interface LinkManService {
    /**
     * 查询所有
     * @param linkManVo
     * @return
     */
    List<LinkMan> findAll();
}

实现类


package com.czxy.crm.service.impl;
import com.czxy.crm.domain.LinkMan;
import com.czxy.crm.mapper.LinkManMapper;
import com.czxy.crm.service.LinkManService;
import com.github.pagehelper.PageHelper;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import tk.mybatis.mapper.entity.Example;
import javax.annotation.Resource;
import java.util.List;
/**
 * @author 桐叔
 * @email liangtong@itcast.cn
 */
@Service
@Transactional
public class LinkManServiceImpl implements LinkManService {
    @Resource
    private LinkManMapper linkManMapper;
    @Override
    public List<LinkMan> findAll() {
        //1 条件查询
        Example example = new Example(LinkMan.class);
        //2 分页查询
        //3 查询
        List<LinkMan> linkManList = linkManMapper.selectByExample(example);
        //4 关联
        linkManList.forEach(linkMan -> {
            Customer customer = customerMapper.selectByPrimaryKey(linkMan.getCustId());
            linkMan.setCustomer(customer);
        });
        //5 封装
        return linkManList;
        //return new PageInfo<>(linkManList);
    }
}

步骤4:修改 linkman/list.jsp 展示数据


<c:forEach items="${linkManList}" var="linkman">
  <TR
  style="FONT-WEIGHT: normal; FONT-STYLE: normal; BACKGROUND-COLOR: white; TEXT-DECORATION: none">
  <TD>${linkman.lkmName }</TD>
  <TD>${linkman.lkmGender }</TD>
  <TD>${linkman.lkmPhone }</TD>
  <TD>${linkman.lkmMobile }</TD>
  <TD>${linkman.lkmEmail }</TD>
  <TD>${linkman.lkmPosition }</TD>
  <TD>${linkman.lkmMemo }</TD>
  <TD>${linkman.customer.custName}</TD>
  <TD>
  <a href="${pageContext.request.contextPath }/linkman/editUI.action?lkmId=${linkman.lkmId}">修改</a>
  &nbsp;&nbsp;
  <a href="javascript:void(0)" οnclick="deleteLinkMan('${linkman.lkmId}','${linkman.lkmName}')">删除</a>
  </TD>
  </TR>
</c:forEach>

4.2.2 条件查询


需求:


步骤:


步骤1:入口,确定查询表单


步骤2:创建LinkManVo,用于封装查询条件


步骤3:修改LinkManController,获得查询条件


步骤4:修改LinkManService,使用查询条件


步骤1:入口,确定查询表单


步骤2:创建LinkManVo,用于封装查询条件


package com.czxy.crm.vo;
/**
 * @author 桐叔
 * @email liangtong@itcast.cn
 */
public class LinkManVo {
    private String lkmName;
    public String getLkmName() {
        return lkmName;
    }
    public void setLkmName(String lkmName) {
        this.lkmName = lkmName;
    }
}

步骤3:修改LinkManController,获得查询条件


步骤4:修改LinkManService,使用查询条件


接口


实现类


package com.czxy.crm.service.impl;
import com.czxy.crm.domain.LinkMan;
import com.czxy.crm.mapper.LinkManMapper;
import com.czxy.crm.service.LinkManService;
import com.czxy.crm.vo.LinkManVo;
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import org.apache.commons.lang3.StringUtils;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import tk.mybatis.mapper.entity.Example;
import javax.annotation.Resource;
import java.util.List;
/**
 * @author 桐叔
 * @email liangtong@itcast.cn
 */
@Service
@Transactional
public class LinkManServiceImpl implements LinkManService {
    @Resource
    private LinkManMapper linkManMapper;
    @Override
    public List<LinkMan> findAll(LinkManVo linkManVo) {
        //1 条件查询
        Example example = new Example(LinkMan.class);
        Example.Criteria criteria = example.createCriteria();
        if(StringUtils.isNotBlank(linkManVo.getLkmName())) {
            criteria.andLike("lkmName", "%"+linkManVo.getLkmName()+"%");
        }
        //2 分页查询
        //3 查询
        List<LinkMan> linkManList = linkManMapper.selectByExample(example);
        //4 关联
        linkManList.forEach(linkMan -> {
            Customer customer = customerMapper.selectByPrimaryKey(linkMan.getCustId());
            linkMan.setCustomer(customer);
        });
        //5 封装
        return linkManList;
    }
}

4.2.3 分页查询


需求:


步骤


步骤1:修改LinkManVo,获得分页参数


步骤2:修改LinkManController,返回pageInfo


步骤3:修改LinkManService,封装PageInfo


步骤4:修改jsp,展示列表数据


步骤5:修改jsp,展示分页条


步骤1:修改LinkManVo,获得分页参数


package com.czxy.crm.vo;
/**
 * @author 桐叔
 * @email liangtong@itcast.cn
 */
public class LinkManVo {
    private String lkmName;
    private Integer pageNum = 1;
    private Integer pageSize = 2;
    //getter和setter
}

步骤2:修改LinkManController,返回pageInfo


步骤3:修改LinkManService,封装PageInfo


接口


实现类


package com.czxy.crm.service.impl;
import com.czxy.crm.domain.Customer;
import com.czxy.crm.domain.LinkMan;
import com.czxy.crm.mapper.CustomerMapper;
import com.czxy.crm.mapper.LinkManMapper;
import com.czxy.crm.service.LinkManService;
import com.czxy.crm.vo.LinkManVo;
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import org.apache.commons.lang3.StringUtils;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import tk.mybatis.mapper.entity.Example;
import javax.annotation.Resource;
import java.util.List;
/**
 * @author 桐叔
 * @email liangtong@itcast.cn
 */
@Service
@Transactional
public class LinkManServiceImpl implements LinkManService {
    @Resource
    private LinkManMapper linkManMapper;
    @Resource
    private CustomerMapper customerMapper;
    @Override
    public PageInfo<LinkMan> findAll(LinkManVo linkManVo) {
        //1 条件查询
        Example example = new Example(LinkMan.class);
        Example.Criteria criteria = example.createCriteria();
        if(StringUtils.isNotBlank(linkManVo.getLkmName())) {
            criteria.andLike("lkmName", "%"+linkManVo.getLkmName()+"%");
        }
        //2 分页查询
        PageHelper.startPage(linkManVo.getPageNum() ,linkManVo.getPageSize());
        //3 查询
        List<LinkMan> linkManList = linkManMapper.selectByExample(example);
        //4 关联
        linkManList.forEach(linkMan -> {
            Customer customer = customerMapper.selectByPrimaryKey(linkMan.getCustId());
            linkMan.setCustomer(customer);
        });
        //5 封装
        return new PageInfo<>(linkManList);
    }
}

步骤4:修改jsp,展示列表数据

步骤5:修改jsp,展示分页条


查询表单


分页条


当前第[<B>${pageInfo.pageNum}</B>]页,共[<B>${pageInfo.total}</B>]条

,每页显示

<select οnchange="change(this)">
    <option value="1" ${pageInfo.pageSize == 1 ? 'selected' : ''}>1</option>
    <option value="2" ${pageInfo.pageSize == 2 ? 'selected' : ''}>2</option>
    <option value="3" ${pageInfo.pageSize == 3 ? 'selected' : ''}>3</option>
    <option value="5" ${pageInfo.pageSize == 5 ? 'selected' : ''}>5</option>
    <option value="10" ${pageInfo.pageSize == 10 ? 'selected' : ''}>10</option>
</select>
<c:if test="${pageInfo.pageNum > 1}">
    [<a href="javascript:void(0)" οnclick="page(1)">首页</a>]
    [<a href="javascript:void(0)" οnclick="page(${pageInfo.pageNum - 1})">上一页</a>]
</c:if>
<c:forEach begin="1" end="${pageInfo.pages}" var="num">
    <b><a href="javascript:void(0)" οnclick="page(${num})">${num}</a></b>
</c:forEach>
<c:if test="${pageInfo.pageNum < pageInfo.pages}">
    [<a href="javascript:void(0)" οnclick="page(${pageInfo.pageNum + 1})">下一页</a>]
    [<a href="javascript:void(0)" οnclick="page(${pageInfo.pages})">尾页</a>]
</c:if>
<input type="number" style="width: 35px;" value="${customerVo.pageNum}" id="goId"/>
<input type="button" value="Go" οnclick="page(goId.value)"/>
JS函数
<SCRIPT language=javascript>
    function change(obj) {
        // 重置,如果修改了pageSize,从1开始
        pageNumId.value = 1
        // 修改隐藏字段 pageSize
        pageSizeId.value = obj.value
        // 提交表单
        linkmanFormId.submit()
    }
    function page(pageNum) {
        // 修改pageNum的值
        pageNumId.value = pageNum
        // 提交表单
        linkmanFormId.submit()
    }
</SCRIPT>

4.3 添加联系人


4.3.1 需求


4.3.2 显示表单


步骤:


步骤1:入口


步骤2:修改LinkManController,用于显示 linkman/add.jsp 页面


查询所有客户


步骤3:编写CustomerService,查询所有客户。


步骤4:修改add.jsp,显示客户列表。


步骤1:入口


步骤2:修改LinkManController,用于显示 linkman/add.jsp 页面


查询所有客户


package com.czxy.crm.controller;
import com.czxy.crm.domain.Customer;
import com.czxy.crm.domain.LinkMan;
import com.czxy.crm.service.CustomerService;
import com.czxy.crm.service.LinkManService;
import com.czxy.crm.vo.CustomerVo;
import com.czxy.crm.vo.LinkManVo;
import com.github.pagehelper.PageInfo;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import javax.annotation.Resource;
import java.util.List;
/**
 * @author 桐叔
 * @email liangtong@itcast.cn
 */
@Controller
@RequestMapping("/linkman")
public class LinkManController {
    @Resource
    private LinkManService linkManService;
    @Resource
    private CustomerService customerService;
    /**
     * 显示添加页面
     * @param model
     * @return
     */
    @RequestMapping("/addUI")
    public String addUI(Model model) {
        // 查询所有客户
        List<Customer> allCustomer = customerService.selectAll();
        model.addAttribute("allCustomer", allCustomer);
        return "linkman/add";
    }
}

步骤3:编写CustomerService,查询所有客户。


接口


 

/**
     * 查询所有
     * @return
     */
    List<Customer> selectAll();

实现类


 

@Override
    public List<Customer> selectAll() {
        return customerMapper.selectAll();
    }

步骤4:修改add.jsp,显示客户列表。


<select name="custId">
    <option value="">--请选择--</option>
    <c:forEach items="${allCustomer}" var="customer">
        <option value="${customer.custId}">${customer.custName}</option>
    </c:forEach>
</select>

4.3.3 添加


步骤:


步骤1:修改add.jsp页面,确定表单提交路径 /linkman/add.action


步骤2:修改LinkManController,添加add方法,并处理成功和失败。


步骤3:修改LinkManService,添加add方法


步骤4:修改add.jsp,显示错误信息


步骤1:修改add.jsp页面,确定表单提交路径 /linkman/add.action


步骤2:修改LinkManController,添加add方法,并处理成功和失败。

/**
     * 添加联系人
     * @param linkMan
     * @param model
     * @return
     */
    @RequestMapping("/add")
    public String add(LinkMan linkMan , Model model) {
        try {
            // 查询所有客户
            boolean result = linkManService.add(linkMan);
            if(result) {
                return "redirect:/linkman/findAll.action";
            } else {
                model.addAttribute("error", "添加联系人失败");
                return "linkman/add";
            }
        } catch (Exception e) {
            e.printStackTrace();
            model.addAttribute("error", e.getMessage());
            return "linkman/add";
        }
    }

步骤3:修改LinkManService,添加add方法


接口


实现类


 

@Override
    public boolean add(LinkMan linkMan) {
        int insert = linkManMapper.insertSelective(linkMan);
        return insert == 1;
    }

步骤4:修改add.jsp,显示错误信息


4.4 修改联系人


4.4.1 需求


4.4.2 显示表单,回显数据

步骤:


步骤1:入口 /linkman/editUI.action?lkmId=1


步骤2:修改LinkManController,用于显示 linkman/edit.jsp 页面


查询所有客户


查询当前联系人


步骤3:编写LinkManService,查询联系人详情。


步骤4:修改edit.jsp,显示客户列表,回显联系人信息。


步骤1:入口 /linkman/editUI.action?lkmId=1


步骤2:修改LinkManController,用于显示 linkman/edit.jsp 页面


查询所有客户


查询当前联系人


 

/**
     * 编辑前操作
     * @param lkmId
     * @param model
     * @return
     */
    @RequestMapping("/editUI")
    public String editUI(Long lkmId, Model model) {
        // 查询所有客户
        List<Customer> allCustomer = customerService.selectAll();
        model.addAttribute("allCustomer", allCustomer);
        // 查询详情
        LinkMan linkMan = linkManService.selectById(lkmId);
        model.addAttribute("linkMan", linkMan);
        return "linkman/edit";
    }

步骤3:编写LinkManService,查询联系人详情。


接口


 

/**
     * 查询详情
     * @param lkmId
     * @return
     */
    LinkMan selectById(Long lkmId);

实现类


 

@Override
    public LinkMan selectById(Long lkmId) {
        return linkManMapper.selectByPrimaryKey(lkmId);
    }

步骤4:修改edit.jsp,显示客户列表,回显联系人信息。


4.4.3 修改


步骤:


步骤1:修改edit.jsp页面,确定表单提交路径 /linkman/edit.action


步骤2:修改LinkManController,添加edit方法,并处理成功和失败。


步骤3:修改LinkManService,添加edit方法


步骤4:修改edit.jsp,显示错误信息


步骤1:修改edit.jsp页面,确定表单提交路径 /linkman/edit.action


步骤2:修改LinkManController,添加edit方法,并处理成功和失败。

/**
     * 修改联系人
     * @param linkMan
     * @param model
     * @return
     */
    @RequestMapping("/edit")
    public String edit(LinkMan linkMan , Model model) {
        try {
            // 查询所有客户
            boolean result = linkManService.update(linkMan);
            if(result) {
                return "redirect:/linkman/findAll.action";
            } else {
                model.addAttribute("error", "修改联系人失败");
                return "linkman/edit";
            }
        } catch (Exception e) {
            e.printStackTrace();
            model.addAttribute("error", e.getMessage());
            return "linkman/edit";
        }
    }

 

 步骤3:修改LinkManService,添加edit方法


接口


实现类


 

@Override
    public boolean update(LinkMan linkMan) {
        int update = linkManMapper.updateByPrimaryKeySelective(linkMan);
        return update == 1;
    }

步骤4:修改edit.jsp,显示错误信息


4.5 删除联系人


步骤:


步骤1:入口 linkman/delete.action?lkmId=1


步骤2:修改LinkManController,添加delete方法,删除成功重定向到列表页。


步骤3:修改LinkManService,添加delete方法


步骤1:入口 linkman/delete.action?lkmId=1


<a href="${pageContext.request.contextPath }/linkman/delete.action?lkmId=${linkman.lkmId}" οnclick="return confirm('您确定要删除【${linkman.lkmName}】吗?')">删除</a>

步骤2:修改LinkManController,添加delete方法,删除成功重定向到列表页。


 

/**
     * 通过id删除联系人
     * @param lkmId
     * @return
     */
    @RequestMapping("/delete")
    public String delete(Long lkmId) {
        // 删除
        linkManService.deleteById(lkmId);
        // 重定向列表页
        return "redirect:/linkman/findAll.action";
    }

步骤3:修改LinkManService,添加delete方法


接口

/**
     * 删除
     * @param lkmId
     */
    void deleteById(Long lkmId);

实现类


 

@Override
    public void deleteById(Long lkmId) {
        linkManMapper.deleteByPrimaryKey(lkmId);
    }

4.6 完善:删除客户


4.6.1 问题:客户和联系人主外键约束


当联系人使用了客户后,此时如果删除客户,默认出现:


4.6.2 解决方案1:自动删除联系人


需求:删除客户前,先删除联系人


步骤:


步骤1:修改 LinkManMapper ,添加 deleteAllByCustId方法


步骤2:修改 CustomerServiceImpl,修改 deleteById 方法


步骤1:修改 LinkManMapper ,添加 deleteAllByCustId方法


package com.czxy.crm.mapper;
import com.czxy.crm.domain.LinkMan;
import org.apache.ibatis.annotations.Delete;
import org.apache.ibatis.annotations.Param;
import tk.mybatis.mapper.common.Mapper;
/**
 * @author 桐叔
 * @email liangtong@itcast.cn
 */
public interface LinkManMapper extends Mapper<LinkMan> {
    /**
     * 删除指定客户的联系人
     * @param custId
     */
    @Delete("DELETE FROM cst_linkman WHERE lkm_cust_id = #{custId}")
    void deleteAllByCustId(@Param("custId") Long custId);
}

步骤2:修改 CustomerServiceImpl,修改 deleteById 方法


 

@Override
    public void deleteById(Long custId) {
        // 依次删除联系人
        linkManMapper.deleteAllByCustId(custId);
        // 删除客户
        customerMapper.deleteByPrimaryKey(custId);
    }

4.6.3 作业:完善删除提示


在删除客户时,完成如下2个需求:


需求1:如果客户==没有==关联的联系人,删除时提示“您确定要删除【xxx】吗?”


需求2:如果客户==有==关联的联系人,删除时提示“【xxx】客户关联3个联系人,您确定一并删除吗?”


目录
打赏
0
0
0
0
81
分享
相关文章
接替此文【下篇-服务端+后台管理】优雅草蜻蜓z系统JAVA版暗影版为例-【蜻蜓z系列通用】-2025年全新项目整合搭建方式-这是独立吃透代码以后首次改变-独立PC版本vue版搭建教程-优雅草卓伊凡
接替此文【下篇-服务端+后台管理】优雅草蜻蜓z系统JAVA版暗影版为例-【蜻蜓z系列通用】-2025年全新项目整合搭建方式-这是独立吃透代码以后首次改变-独立PC版本vue版搭建教程-优雅草卓伊凡
233 96
接替此文【下篇-服务端+后台管理】优雅草蜻蜓z系统JAVA版暗影版为例-【蜻蜓z系列通用】-2025年全新项目整合搭建方式-这是独立吃透代码以后首次改变-独立PC版本vue版搭建教程-优雅草卓伊凡
Java网络编程,多线程,IO流综合小项目一一ChatBoxes
**项目介绍**:本项目实现了一个基于TCP协议的C/S架构控制台聊天室,支持局域网内多客户端同时聊天。用户需注册并登录,用户名唯一,密码格式为字母开头加纯数字。登录后可实时聊天,服务端负责验证用户信息并转发消息。 **项目亮点**: - **C/S架构**:客户端与服务端通过TCP连接通信。 - **多线程**:采用多线程处理多个客户端的并发请求,确保实时交互。 - **IO流**:使用BufferedReader和BufferedWriter进行数据传输,确保高效稳定的通信。 - **线程安全**:通过同步代码块和锁机制保证共享数据的安全性。
96 23
java spring 项目若依框架启动失败,启动不了服务提示端口8080占用escription: Web server failed to start. Port 8080 was already in use. Action: Identify and stop the process that’s listening on port 8080 or configure this application to listen on another port-优雅草卓伊凡解决方案
java spring 项目若依框架启动失败,启动不了服务提示端口8080占用escription: Web server failed to start. Port 8080 was already in use. Action: Identify and stop the process that’s listening on port 8080 or configure this application to listen on another port-优雅草卓伊凡解决方案
121 7
|
8月前
|
解决idea每次新建maven项目都需要重新配置maven的问题
解决idea每次新建maven项目都需要重新配置maven的问题
308 1
|
5月前
|
从零开始学 Maven:简化 Java 项目的构建与管理
Maven 是一个由 Apache 软件基金会开发的项目管理和构建自动化工具。它主要用在 Java 项目中,但也可以用于其他类型的项目。
156 1
从零开始学 Maven:简化 Java 项目的构建与管理
|
5月前
|
maven项目的pom.xml文件常用标签使用介绍
第四届人文,智慧教育与服务管理国际学术会议(HWESM 2025) 2025 4th International Conference on Humanities, Wisdom Education and Service Management
522 8
Maven——创建 Spring Boot项目
Maven 是一个项目管理工具,通过配置 `pom.xml` 文件自动获取所需的 jar 包,简化了项目的构建和管理过程。其核心功能包括项目构建和依赖管理,支持创建、编译、测试、打包和发布项目。Maven 仓库分为本地仓库和远程仓库,远程仓库包括中央仓库、私服和其他公共库。此外,文档还介绍了如何创建第一个 SpringBoot 项目并实现简单的 HTTP 请求响应。
488 1
Maven——创建 Spring Boot项目
Maven的三种项目打包方式——pom,jar,war的区别
Maven 提供了多种打包方式,分别适用于不同类型的项目。pom 用于父项目或聚合项目,便于项目的结构和依赖管理;jar 用于Java类库或可执行的Java应用程序;war 则专用于Java Web应用程序的部署。理解这些打包方式的用途和特点,可以帮助开发者更好地配置和管理Maven项目,确保构建和部署过程的顺利进行。无论是单模块项目还是多模块项目,选择合适的打包方式对于项目的成功至关重要。
658 3
如何使用 maven 创建一个 Spring Boot项目
Maven 是一个强大的项目管理工具,通过配置 `pom.xml` 文件自动获取所需的 jar 包,提高开发效率。其核心功能包括项目构建和依赖管理。项目构建支持编译、测试、打包和发布等流程,而依赖管理则通过中央仓库、本地仓库和私有服务器获取和管理项目依赖。示例中展示了如何创建第一个 SpringBoot 项目并实现简单接口。
144 1
如何使用 maven 创建一个 Spring Boot项目
|
6月前
|
idea maven创建kotlin项目
本文介绍了在IntelliJ IDEA中使用Maven创建Kotlin项目的步骤,包括在`pom.xml`文件中添加Maven中央仓库、配置`kotlin-maven-plugin`插件、指定源目录、添加测试插件和执行插件,以及添加Kotlin测试依赖和标准库依赖。文中还提到了如何通过更换镜像或使用代理来解决依赖下载速度慢的问题,并展示了运行示例代码的截图。
402 4
idea maven创建kotlin项目

推荐镜像

更多