二十一、线索转换3:线索的备注转化为客户联系人的备注

news2024/10/7 18:27:39

功能需求

3.线索的备注信息--》客户备注

4.线索的备注---》联系人备注

5.线索市场活动关系---》联系人市场活动关系

流程图

代码实现:线索的备注转化为客户联系人的备注

1.clueRemarkMapper

    /**
     * 根据线索id 查询备注2
     */
    List<ClueRemark> selectInitialClueRemarkByClueId(String clueId);
    <select id="selectInitialClueRemarkByClueId" resultMap="BaseResultMap">
        select
        <include refid="Base_Column_List"/>
        from tbl_clue_remark
        where clue_id=#{clueId}
    </select>

2.CustomerRemarkMapper

    /**
     * 线索备注--客户备注
     */
    int insertCustomerRemarkByList(List<CustomerRemark> customerRemarkList);
    <insert id="insertCustomerRemarkByList">
        insert into tbl_customer_remark (id, note_content, create_by,
        create_time, edit_by, edit_time,
        edit_flag, customer_id)
        values
        <foreach collection="list" separator="," item="obj">
            (#{obj.id},#{obj.noteContent},#{obj.createBy},#{obj.createTime},#{obj.editBy},#{obj.editTime},#{obj.editFlag},#{obj.customerId})
        </foreach>
    </insert>

3.ContactsRemarkMapper

    /**
     * 线索备注--联系人备注
     */
    int insertContactsRemarkByList(List<ContactsRemark> contactsRemarkList);
  <insert id="insertContactsRemarkByList">
    insert into tbl_contacts_remark(id, note_content, create_by, create_time, edit_by, edit_time, edit_flag, contacts_id)
    values
    <foreach collection="list" item="obj" separator=",">
      (#{obj.id},#{obj.noteContent},#{obj.createBy},#{obj.createTime},#{obj.editBy},#{obj.editTime},#{obj.editFlag},#{obj.contactsId})
    </foreach>
  </insert>

4.ClueService

//3.线索评论--客户评论和联系人评论
		List<ClueRemark> clueRemarkList = clueRemarkMapper.selectInitialClueRemarkByClueId(clueId);
		// 如果线索不是空的
		if (clueRemarkList != null && clueRemarkList.size() > 0) {
			// 遍历线索备注
			CustomerRemark customerRemark = null;
			List<CustomerRemark> customerRemarkList = new ArrayList<>();
			ContactsRemark contactsRemark = null;
			List<ContactsRemark> contactsRemarkList = new ArrayList<>();
			// 遍历备注信息
			for (ClueRemark clueRemark : clueRemarkList) {
				customerRemark = new CustomerRemark();
				customerRemark.setId(UUIDUtils.getUUID());
				customerRemark.setNoteContent(clueRemark.getNoteContent());
				customerRemark.setCreateBy(clueRemark.getCreateBy());
				customerRemark.setCreateTime(clueRemark.getCreateTime());
				customerRemark.setEditBy(clueRemark.getEditBy());
				customerRemark.setEditTime(clueRemark.getEditTime());
				customerRemark.setEditFlag(clueRemark.getEditFlag());
				customerRemark.setCustomerId(customer.getId());
				customerRemarkList.add(customerRemark);

				contactsRemark = new ContactsRemark();
				contactsRemark.setId(UUIDUtils.getUUID());
				contactsRemark.setNoteContent(clueRemark.getNoteContent());
				contactsRemark.setCreateBy(clueRemark.getCreateBy());
				contactsRemark.setCreateTime(clueRemark.getCreateTime());
				contactsRemark.setEditBy(clueRemark.getEditBy());
				contactsRemark.setEditTime(clueRemark.getEditTime());
				contactsRemark.setEditFlag(clueRemark.getEditFlag());
				contactsRemark.setContactsId(contacts.getId());
				contactsRemarkList.add(contactsRemark);
			}
			// 调用sql插入
			customerRemarkMapper.insertCustomerRemarkByList(customerRemarkList);
			contactsRemarkMapper.insertContactsRemarkByList(contactsRemarkList);
		}


代码实现:联系人市场活动关系

 

1.ClueActivityRelationMapper

    /**
     * 根据线索id查询关联得市场活动
     */
    List<ClueActivityRelation> selectClueActivityRelationByClueId(String clueId);
    <!--List<ClueActivityRelation> selectClueActivityRelationByClueId(String clueId);-->
    <select id="selectClueActivityRelationByClueId" resultMap="BaseResultMap">
        select
        <include refid="Base_Column_List"/>
        from tbl_clue_activity_relation
        where clue_id = #{clueId}
    </select>

2.ContactsActivityRelationMapper

    /**
     *  批量插入 市场关联
     */
    int insertContactsActivityRelationByList(List<ContactsActivityRelation> contactsActivityRelationList);
    <!-- int insertContactsActivityRelationByList(List<ContactsActivityRelation> contactsActivityRelationList);-->
    <insert id="insertContactsActivityRelationByList">
        insert into tbl_contacts_activity_relation (id, contacts_id, activity_id
        )
        values
        <foreach collection="list" item="obj" separator=",">
            (#{obj.id}, #{obj.contactsId}, #{obj.activityId})
        </foreach>
    </insert>

3.ClueService

		// 4.线索市场活动关系---联系人市场活动
		List<ClueActivityRelation> clueActivityRelationList = clueActivityRelationMapper.selectClueActivityRelationByClueId(clueId);
		// 查询得结果不为空
		if (clueActivityRelationList != null && clueActivityRelationList.size() > 0) {
			ContactsActivityRelation contactsActivityRelation = null;
			List<ContactsActivityRelation> contactsActivityRelationList = new ArrayList<>();
			for (ClueActivityRelation clueActivityRelation : clueActivityRelationList) {
				contactsActivityRelation = new ContactsActivityRelation();
				contactsActivityRelation.setId(UUIDUtils.getUUID());
				contactsActivityRelation.setContactsId(contacts.getId());
				contactsActivityRelation.setActivityId(clueActivityRelation.getActivityId());
				contactsActivityRelationList.add(contactsActivityRelation);
			}
			// 插入市场活动
			contactsActivityRelationMapper.insertContactsActivityRelationByList(contactsActivityRelationList);
		}

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

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

相关文章

Windows本地MySQL升级

一、删除原来的MySQL 删除 C:\Programs Files、C:\Programs Files(x86)、C:\ProgramData 中的所有MySQL目录 找到MySQL数据库中的data保存到其他位置&#xff0c;升级后可以恢复数据库数据 【备份数据】 删除注册表中MySQL的信息 计算机\HKEY_LOCAL_MACHINE\SYSTEM\ControlSet…

Py01·环境搭建

Python环境搭建 官网下载python3.7.3&#xff1a;https://www.python.org/downloads/release/python-373/ 配置系统环境变量目录&#xff1a; E:\ldtools\python3.7.3\python.exe E:\ldtools\python3.7.3\Scripts\pip.exe python.exe 运行环境 pip.exe 包管理器 安装mysql环…

TypeScript 最近各版本主要特性总结

&#xff08;在人生的道路上&#xff0c;当你的期望一个个落空的时候&#xff0c;你也要坚定&#xff0c;要沉着。——朗费罗&#xff09; TypeScript 官网 在线运行TypeScript代码 第三方中文博客 特性 typescript是javascript的超集&#xff0c;向javascript继承额外的编辑…

K8s之Namespace名称空间详解

文章目录 一、名称空间概念二、名称空间基本操作1、创建Namespace的两种方式2、Namespace资源限额 一、名称空间概念 K8s中文手册&#xff1a; K8s名称空间中文官方手册&#xff1a; Kubernetes 支持多个虚拟集群&#xff0c;它们底层依赖于同一个物理集群。 这些虚拟集群被…

UUID使用

1.UUID是什么&#xff1f; UUID 是指&#xff08;Universally Unique Identifier&#xff09;通用唯一识别码&#xff0c;128位。RFC 4122描述了具体的规范实现。 2.UUID解决问题&#xff1f; 分库分表后自增Id重复问题。 3.UUID作用&#xff1f; UUID 的目的是让分布式系…

[数据库系统] 一、创建表以及使用主键约束(educoder)

1.任务&#xff1a;在数据库中创建一个表。 2.需要掌握&#xff1a; 如何在指定数据库中创建表。 知识点&#xff1a;如何在指定数据库中创建表。 我们先来了解一下在数据库中创建表的规则&#xff1a; CREATE TABLE 表名(字段名,数据类型,字段名,数据类型,.....) 例如&…

Oracle 体系结构

文章目录 Oracle体系结构Oracle的内存结构Oracle的进程结构服务器进程后台进程可选后台进程 物理存储结构逻辑存储结构 概念&#xff1a; Oracle server由Oracle instance和Oracle database组成&#xff0c;Oracle instance由后台进程和共享内存组成&#xff0c;Oracle的实例包…

《走进对象村4》之面向对象的第一大特性——封装

文章目录 &#x1f680;文章导读1、封装的概念2、访问限定修饰符3、如何进行封装4、封装的优点&#xff1a; &#x1f680;文章导读 在本篇文章中&#xff0c;将详细的对封装进行总结&#xff0c;文章仅仅是个人的一些理解&#xff0c;如果有错误的地方&#xff0c;还望指出看完…

八岁都能懂:O(N)条件下在N个元素中找出第K小的元素

目录 1 进入情境1-1 金字塔道具1-2 感觉还不够1-3 万能筛子1-4 怎么用呢 2 代码实现2-1 伪代码描述2-2 完整实例c 3 引申3-1 完美的折半舍弃3-2 找出前K小的元素(topK方法&#xff09;3-3 O(n)效率下求中位数参考资料 1 进入情境 生日&#xff0c;朋友送了一堆弹珠&#xff0c;…

[PyTorch][chapter31][卷积]

前言&#xff1a; 卷积神经网络 是 计算机视觉里面应用非常广泛的一个模型。 卷积神经网络 成功案例 人脸识别,指纹识别等应用. 卷积的本质是图像的特征提取&#xff0c; 在冈萨雷士版本《数字图像处理》处理有专门的章节讲解 各种卷积核&#xff0c;在通讯原理里面&#xff0…

MOD09A1、MYD09A1 文件说明

总体介绍 文件全称为 MODIS Terra/Aqua Surface Reflectance 8-Day L3 Global 500 m。文件名称的示例为 “MOD09A1.A2000337.h11v05.005.2006342055602.hdf”。下载下来的 hdf 包括 13 个子数据集&#xff0c;一个 tile 包括 2400*2400 个像元。各数据集的性质如下表所示。 Sci…

51单片机基础实验1

一.51单片机 51单片机&#xff0c;也称为AT89C51&#xff0c;是一种基于Intel 8051架构的8位单片机。它是广泛应用于嵌入式系统和微控制器领域的常见芯片之一。其具有高度灵活性、可编程性和可靠性&#xff0c;因此被广泛应用于各种应用场景中。 51单片机的主要特点包括&…

三十、组播技术——IGMP、IGMP-snooping、PIM-DM、PIM-SM

文章目录 组播概述1、IP组播通信概念2、组播和单播ip地址3、组播MAC4、组播应用场景5、PIM、IGMP、IGMP-snooping 一、IGMP 协议二、PIM DM&#xff08;密集模式&#xff09;1、配置示例如下&#xff1a;2、PIM DM的局限性 三、PM SM&#xff08;稀疏模式&#xff09; 组播概述…

【python学习】基础篇-文件与系统-os 模块及 os.path 相对路径与绝对路径

在 Python 中&#xff0c;内置了os 模块及其子模块 ospath&#xff0c;用于对目录或文件进行操作。 在使用 os 模块或者 os.path 模块时&#xff0c;应首先使用 import 语句将其导入&#xff0c;然后才可以使用它们提供的函数或方法。 1、常用操作目录函数 2.相对路径与绝对路…

如何手写一个支持H.265的高清播放器

概述 音视频编解码技术在当前的互联网行业中十分热门&#xff0c;特别是高清视频播放器的开发&#xff0c;其中包括4K、8K等超高清分辨率的播放器&#xff0c;具有极高的市场需求和广泛的应用场景。H265编码技术更是实现高清视频压缩的重要手段之一。如果想要掌握音视频编解码…

微服务部署:蓝绿发布、滚动发布、灰度发布、金丝雀发布

前言 在项目迭代的过程中&#xff0c;不可避免需要上线。上线对应着部署&#xff0c;或者重新部署&#xff1b;部署对应着修改,修改则意味着风险。 1.蓝绿发布(Blue/Green Deployment) ①定义 蓝绿部署是不停老版本&#xff0c;部署新版本然后进行测试。确认OK后将流量切到新…

ADSP21489之CCES开发笔记(十一)

一、主模式固件加载&#xff1a; 1、激活SPICLK信号&#xff0c;并将SPI_FLG0_O引脚拉低。 2、将读取命令0x03和24位地址0x000000写入从设备。如图24-4所示。 图24-4 二、PCAG时钟选择与配置。 1、来源晶振 2、来源Pin脚 其中来源Pin脚配置PCAG时&#xff0c;需将PCG_CTLx1上加…

如何生成api接口获取宝贝商品详情,商品详情接口,产品详情

API (Application Programming Interface)是指应用程序接口&#xff0c;它是一种通过编写一组统一的规则&#xff0c;开发一个软件来与其他应用程序进行通讯的技术。API可以方便应用程序之间的交流和数据共享&#xff0c;以及增强应用程序的功能。 在现代应用程序中&#xff0…

23.自定义指令

像是 v-if,v-for,v-model 这些是官方指令&#xff0c;vue允许开发者自定义指令 目录 1 mounted 1.1 基本使用 1.2 第一个形参 1.3 第二个形参 2 updated 3 函数简写 4 全局自定义指令 1 mounted 当指令绑定到元素身上的时候&#xff0c;就会自动触发mounted()…

MySQL---基本操作DQL(基本查询语法,算术运算符,比较运算符,逻辑运算符,位运算符)

1. 基本查询语法 select [all|distinct] <目标列的表达式1> [别名], <目标列的表达式2> [别名]... from <表名或视图名> [别名],<表名或视图名> [别名]... [where<条件表达式>] [group by <列名> [having <条件表达式>]] [o…