AEAI CRM V1.6.0 升级说明,开源客户关系管理系统
1 升级说明
AEAI CRM v1.6.0版是AEAI CRM v1.5.2版客户关系管理系统的升级版本,本次版本是基于AEAI DP v3.8.0_20170228进行打包部署的,升级内容主要是针对数通畅联销售对客户拜访任务管理进行的一次全面的升级,整体的业务流程发生了重大变化,加强了每个销售人员对自己客户关系管理,每周的客户拜访任务模式。
另外,AEAI CRM根据实际应用过程中客户反馈,对相关功能进行修正,同时完善部分功能、优化用户体验。产品现已开源,下载地址:http://pan.baidu.com/s/1mgIdzGc。
2 升级内容
1. 新特性
1) 潜在客户,添加分配功能,销售人员可以分配给其他销售
2) 添加潜在客户拜访记录(填写人、填写时间、拜访时间、沟通效果、拜访类型拜访备注可选择),并显示关联我的客户的拜访记录。
3) 添加周期定义功能模块。
4) 添加我的任务功能模块。
5) 添加任务审查功能模块。
2. 功能完善
1) 潜在客户,个体资源标签删除掉、保留组织资源标签、独立显示。
2) 潜在客户,把客户进行数据隔离,只能看见自己创建的客户和分配给自己的客户(唯一查看,分配给别人后,自己就不能查看到)
3) 提供潜在客户导入功能,提供导入excel模板下载
4) 我的客户,要能看到潜在客户变成客户的潜在客户拜访记录。
5) 我的客户,删除excel导出功能。
6) 客户信息,在左侧树添加以销售人员纬度的树。
7) 客户信息,树列表项后显示分类下的客户总数。
3. 数据表调整:
4. 角色添加
INSERT INTO `aeaicrm`.`security_role` (`ROLE_ID`, `ROLE_CODE`, `ROLE_NAME`, `ROLE_PID`, `ROLE_DESC`, `ROLE_STATE`, `ROLE_SORT`) VALUES ('05FC4E42-2BCF-4651-BDFF-86444D055695', 'SALES_MANAGER', '销售经理', '00000000-0000-0000-00000000000000000', '', '1', '7'); INSERT INTO `aeaicrm`.`security_role` (`ROLE_ID`, `ROLE_CODE`, `ROLE_NAME`, `ROLE_PID`, `ROLE_DESC`, `ROLE_STATE`, `ROLE_SORT`) VALUES ('9C7CFCED-8479-43B6-B2FE-5CAA663C2D51', 'SALES_ASSISTANT', '销售助理', '00000000-0000-0000-00000000000000000', '', '1', '9'); |
5. 删除潜在客户个人资源,重新创建潜在客户页面
INSERT INTO `aeaicrm`.`sys_function` (`FUNC_ID`, `FUNC_NAME`, `FUNC_TYPE`, `MAIN_HANDLER`, `FUNC_PID`, `FUNC_STATE`, `FUNC_SORT`, `FUNC_DESC`) VALUES ('3F23DD59-DB0D-4A25-851F-39E63E3944ED', '潜在客户', 'funcnode', '2287114B-17C2-4E88-8A2F-505709ADB719', '029FB2F2-370F-46D5-A283-A22C8E49341C', '1', '2', ''); INSERT INTO `aeaicrm`.`sys_handler` (`HANLER_ID`, `HANLER_CODE`, `HANLER_TYPE`, `HANLER_URL`, `FUNC_ID`) VALUES ('2287114B-17C2-4E88-8A2F-505709ADB719', 'OrgInfoManageList', 'MAIN', NULL, '3F23DD59-DB0D-4A25-851F-39E63E3944ED'); INSERT INTO `aeaicrm`.`sys_handler` (`HANLER_ID`, `HANLER_CODE`, `HANLER_TYPE`, `HANLER_URL`, `FUNC_ID`) VALUES ('F63CF10B-C61B-448B-BA04-1D07BD6927ED', 'OrgInfoManageEdit', 'OTHER', '', '3F23DD59-DB0D-4A25-851F-39E63E3944ED'); INSERT INTO `aeaicrm`.`sys_handler` (`HANLER_ID`, `HANLER_CODE`, `HANLER_TYPE`, `HANLER_URL`, `FUNC_ID`) VALUES ('FE46C2D2-9BD5-4DEA-8A04-AAC5CA4AB1C9', 'LabelsTreeSelect', 'OTHER', '', '3F23DD59-DB0D-4A25-851F-39E63E3944ED'); INSERT INTO `aeaicrm`.`sys_operation` (`OPER_ID`, `HANLER_ID`, `OPER_CODE`, `OPER_NAME`, `OPER_ACTIONTPYE`, `OPER_SORT`) VALUES ('EDCAA320-B057-11E6-B2F9-3B17C38C739D', '2287114B-17C2-4E88-8A2F-505709ADB719', 'edit', '编辑', 'edit', '2'); INSERT INTO `aeaicrm`.`sys_operation` (`OPER_ID`, `HANLER_ID`, `OPER_CODE`, `OPER_NAME`, `OPER_ACTIONTPYE`, `OPER_SORT`) VALUES ('EDDEBE8A-B057-11E6-B2F9-3B17C38C739D', '2287114B-17C2-4E88-8A2F-505709ADB719', 'phoneCall', '电话拜访', 'phoneCall', '3'); INSERT INTO `aeaicrm`.`sys_operation` (`OPER_ID`, `HANLER_ID`, `OPER_CODE`, `OPER_NAME`, `OPER_ACTIONTPYE`, `OPER_SORT`) VALUES ('EDEA88F5-B057-11E6-B2F9-3B17C38C739D', '2287114B-17C2-4E88-8A2F-505709ADB719', 'delete', '删除', 'delete', '5'); INSERT INTO `aeaicrm`.`sys_operation` (`OPER_ID`, `HANLER_ID`, `OPER_CODE`, `OPER_NAME`, `OPER_ACTIONTPYE`, `OPER_SORT`) VALUES ('EDF62B72-B057-11E6-B2F9-3B17C38C739D', '2287114B-17C2-4E88-8A2F-505709ADB719', 'detail', '查看', 'detail', '4'); INSERT INTO `aeaicrm`.`sys_operation` (`OPER_ID`, `HANLER_ID`, `OPER_CODE`, `OPER_NAME`, `OPER_ACTIONTPYE`, `OPER_SORT`) VALUES ('EE00387B-B057-11E6-B2F9-3B17C38C739D', '2287114B-17C2-4E88-8A2F-505709ADB719', 'create', '新增', 'create', '1'); INSERT INTO `aeaicrm`.`sys_operation` (`OPER_ID`, `HANLER_ID`, `OPER_CODE`, `OPER_NAME`, `OPER_ACTIONTPYE`, `OPER_SORT`) VALUES ('74CEE600-B058-11E6-B2F9-3B17C38C739D', 'F63CF10B-C61B-448B-BA04-1D07BD6927ED', 'phoneCall', '电话拜访', 'phoneCall', '3'); INSERT INTO `aeaicrm`.`sys_operation` (`OPER_ID`, `HANLER_ID`, `OPER_CODE`, `OPER_NAME`, `OPER_ACTIONTPYE`, `OPER_SORT`) VALUES ('74E27603-B058-11E6-B2F9-3B17C38C739D', 'F63CF10B-C61B-448B-BA04-1D07BD6927ED', 'save', '保存', 'save', '2'); INSERT INTO `aeaicrm`.`sys_operation` (`OPER_ID`, `HANLER_ID`, `OPER_CODE`, `OPER_NAME`, `OPER_ACTIONTPYE`, `OPER_SORT`) VALUES ('74E97FC3-B058-11E6-B2F9-3B17C38C739D', 'F63CF10B-C61B-448B-BA04-1D07BD6927ED', 'edit', '编辑', 'edit', '1'); INSERT INTO `aeaicrm`.`sys_operation` (`OPER_ID`, `HANLER_ID`, `OPER_CODE`, `OPER_NAME`, `OPER_ACTIONTPYE`, `OPER_SORT`) VALUES ('74F0FB97-B058-11E6-B2F9-3B17C38C739D', 'F63CF10B-C61B-448B-BA04-1D07BD6927ED', 'back', '返回', 'back', '4'); |
6. 潜在客户标签编码内容整体完善修改,删除原有的潜在客户标签编码
INSERT INTO `aeaicrm`.`sys_codelist` (`TYPE_ID`, `CODE_ID`, `CODE_NAME`, `CODE_DESC`, `CODE_SORT`, `CODE_FLAG`) VALUES ('ORG_LABELS', '1', '无人接听', '', '1', '1'); INSERT INTO `aeaicrm`.`sys_codelist` (`TYPE_ID`, `CODE_ID`, `CODE_NAME`, `CODE_DESC`, `CODE_SORT`, `CODE_FLAG`) VALUES ('ORG_LABELS', '2', '号码信息不符', '', '2', '1'); INSERT INTO `aeaicrm`.`sys_codelist` (`TYPE_ID`, `CODE_ID`, `CODE_NAME`, `CODE_DESC`, `CODE_SORT`, `CODE_FLAG`) VALUES ('ORG_LABELS', '3', '空号', '', '3', '1'); INSERT INTO `aeaicrm`.`sys_codelist` (`TYPE_ID`, `CODE_ID`, `CODE_NAME`, `CODE_DESC`, `CODE_SORT`, `CODE_FLAG`) VALUES ('ORG_LABELS', '4', '暂停服务', '', '4', '1'); INSERT INTO `aeaicrm`.`sys_codelist` (`TYPE_ID`, `CODE_ID`, `CODE_NAME`, `CODE_DESC`, `CODE_SORT`, `CODE_FLAG`) VALUES ('ORG_LABELS', '5', '暂无需求', '', '5', '1'); INSERT INTO `aeaicrm`.`sys_codelist` (`TYPE_ID`, `CODE_ID`, `CODE_NAME`, `CODE_DESC`, `CODE_SORT`, `CODE_FLAG`) VALUES ('ORG_LABELS', '6', '后续联系', '', '6', '1'); INSERT INTO `aeaicrm`.`sys_codelist` (`TYPE_ID`, `CODE_ID`, `CODE_NAME`, `CODE_DESC`, `CODE_SORT`, `CODE_FLAG`) VALUES ('ORG_LABELS', '7', '态度恶劣', '', '7', '1'); |
7. 添加潜在客户来源渠道
INSERT INTO `aeaicrm`.`sys_codetype` (`TYPE_ID`, `TYPE_NAME`, `TYPE_GROUP`, `TYPE_DESC`, `IS_CACHED`, `IS_UNITEADMIN`, `IS_EDITABLE`, `LEGNTT_LIMIT`, `CHARACTER_LIMIT`, `EXTEND_SQL`, `SQL_BODY`, `SQL_COND`) VALUES ('ORG_SOURCES', '潜在客户来源渠道', 'app_code_define', '', 'Y', 'Y', 'Y', '', '', 'N', '', ''); INSERT INTO `aeaicrm`.`sys_codelist` (`TYPE_ID`, `CODE_ID`, `CODE_NAME`, `CODE_DESC`, `CODE_SORT`, `CODE_FLAG`) VALUES ('ORG_SOURCES', 'INFO_ACQUIRE', '信息采集', '', '2', '1'); INSERT INTO `aeaicrm`.`sys_codelist` (`TYPE_ID`, `CODE_ID`, `CODE_NAME`, `CODE_DESC`, `CODE_SORT`, `CODE_FLAG`) VALUES ('ORG_SOURCES', 'RECRUIT_ACQUIRE', '招聘采集', '', '3', '1'); INSERT INTO `aeaicrm`.`sys_codelist` (`TYPE_ID`, `CODE_ID`, `CODE_NAME`, `CODE_DESC`, `CODE_SORT`, `CODE_FLAG`) VALUES ('ORG_SOURCES', 'WEB_SEARCH', '网络搜索', '', '1', '1'); |
8. 我的任务-状态编码
INSERT INTO `aeaicrm`.`sys_codetype` (`TYPE_ID`, `TYPE_NAME`, `TYPE_GROUP`, `TYPE_DESC`, `IS_CACHED`, `IS_UNITEADMIN`, `IS_EDITABLE`, `LEGNTT_LIMIT`, `CHARACTER_LIMIT`, `EXTEND_SQL`, `SQL_BODY`, `SQL_COND`) VALUES ('TASK_REVIEW_STATE', '我的任务状态', 'app_code_define', '', 'Y', 'Y', 'Y', '', '', 'N', '', ''); INSERT INTO `aeaicrm`.`sys_codelist` (`TYPE_ID`, `CODE_ID`, `CODE_NAME`, `CODE_DESC`, `CODE_SORT`, `CODE_FLAG`) VALUES ('TASK_REVIEW_STATE', 'ConfirmPlan', '确认计划', '', '3', '1'); INSERT INTO `aeaicrm`.`sys_codelist` (`TYPE_ID`, `CODE_ID`, `CODE_NAME`, `CODE_DESC`, `CODE_SORT`, `CODE_FLAG`) VALUES ('TASK_REVIEW_STATE', 'ConfirmSummary', '确认总结', '', '5', '1'); INSERT INTO `aeaicrm`.`sys_codelist` (`TYPE_ID`, `CODE_ID`, `CODE_NAME`, `CODE_DESC`, `CODE_SORT`, `CODE_FLAG`) VALUES ('TASK_REVIEW_STATE', 'Init', '初始化', '', '1', '1'); INSERT INTO `aeaicrm`.`sys_codelist` (`TYPE_ID`, `CODE_ID`, `CODE_NAME`, `CODE_DESC`, `CODE_SORT`, `CODE_FLAG`) VALUES ('TASK_REVIEW_STATE', 'SubmitPlan', '提交计划', '', '2', '1'); INSERT INTO `aeaicrm`.`sys_codelist` (`TYPE_ID`, `CODE_ID`, `CODE_NAME`, `CODE_DESC`, `CODE_SORT`, `CODE_FLAG`) VALUES ('TASK_REVIEW_STATE', 'SubmitSummary', '提交总结', '', '4', '1'); |
9. 任务跟进状态 – 编码
INSERT INTO `aeaicrm`.`sys_codetype` (`TYPE_ID`, `TYPE_NAME`, `TYPE_GROUP`, `TYPE_DESC`, `IS_CACHED`, `IS_UNITEADMIN`, `IS_EDITABLE`, `LEGNTT_LIMIT`, `CHARACTER_LIMIT`, `EXTEND_SQL`, `SQL_BODY`, `SQL_COND`) VALUES ('TASK_FOLLOW_STATUS', '任务跟进状态', 'app_code_define', '', 'Y', 'Y', 'Y', '', '', 'N', '', ''); INSERT INTO `aeaicrm`.`sys_codelist` (`TYPE_ID`, `CODE_ID`, `CODE_NAME`, `CODE_DESC`, `CODE_SORT`, `CODE_FLAG`) VALUES ('TASK_FOLLOW_STATUS', 'HaveFollowUp', '已跟进', '', '2', '1'); INSERT INTO `aeaicrm`.`sys_codelist` (`TYPE_ID`, `CODE_ID`, `CODE_NAME`, `CODE_DESC`, `CODE_SORT`, `CODE_FLAG`) VALUES ('TASK_FOLLOW_STATUS', 'NoFollowUp', '未跟进', '', '1', '1'); |
10. 拜访类别 – 编码
INSERT INTO `aeaicrm`.`sys_codelist` (`TYPE_ID`, `CODE_ID`, `CODE_NAME`, `CODE_DESC`, `CODE_SORT`, `CODE_FLAG`) VALUES ('TASK_CLASS', 'ColdCalls', '陌生拜访', '', '1', '1'); INSERT INTO `aeaicrm`.`sys_codelist` (`TYPE_ID`, `CODE_ID`, `CODE_NAME`, `CODE_DESC`, `CODE_SORT`, `CODE_FLAG`) VALUES ('TASK_CLASS', 'FollowUp', '意向跟进', '', '2', '1'); |
11. 添加周期定义表
create table CRM_TASK_CYCLE ( TC_ID char(36) not null, TC_BEGIN varchar(32), TC_END varchar(32), TC_FID char(36), primary key (TC_ID) ); |
12. 添加任务计划&总结表
create table CRM_TASK_REVIEW ( TASK_REVIEW_ID char(36) not null, TC_ID char(36), SALE_ID char(36), TASK_REVIEW_STATE varchar(32), TASK_REVIEW_DESC text, TASK_REVIEW_VISITS_TOTAL int(11), TASK_REVIEW_STRANGE int(11), TASK_REVIEW_RETURNVISIT int(11), TASK_REVIEW_NEW_INTENCUST int(11), TASK_REVIEW_RETURNVISIT_HIST int(11), TASK_REVIEW_LOSS int(11), primary key (TASK_REVIEW_ID) ); |
13. 添加我的任务表
create table CRM_MY_TASKS ( TASK_ID char(36) not null, ORG_ID char(36), CUST_ID char(36), TASK_REVIEW_ID char(36), SALE_ID char(36), TASK_FOLLOW_STATE varchar(32), TASK_CLASS varchar(32), TASK_CREATE_TIME varchar(32), TASK_FINISH_TIME varchar(32), TASK_CUST_STATE varchar(32), primary key (TASK_ID) ); |
14. 添加潜在客户拜访记录表
create table CRM_PROCUST_VISIT ( PROCUST_VISIT_ID char(36) not null, ORG_ID char(36), PROCUST_VISIT_DATE date, PROCUST_VISIT_TYPE varchar(32), PROCUST_VISIT_REMARK varchar(1024), PROCUST_VISIT_FILL_ID char(36), PROCUST_VISIT_FILL_TIME datetime, PROCUST_VISIT_EFFECT varchar(32), PROCUST_VISIT_CUST_FOCUS varchar(32), primary key (PROCUST_VISIT_ID) ); |
3 升级步骤
- 由于本次升级内容较多,建议重新部署新版AEAI CRM系统;
- 数据表对应调整参见升级内容对应调整。
AEAI CRM V1.6.0 升级说明,开源客户关系管理系统的更多相关文章
- AEAI WM v1.6.0 升级说明,开源工作管理系统
1 升级说明 AEAI WM v1.6.0版是AEAI WM v1.5.0版工作管理系统的升级版本,本次升级的系统是基于AEAI DP 3.8.0_20170228进行打包部署的,对产品中的功能及BU ...
- AEAI CRM_v1.5.2升级说明,开源客户关系管理系统
1.升级说明 本次AEAI CRM升级内容主要是针对数通畅联推出AEAI ECP企业云联平台而升级的,其中对AEAI CRM的各模块进行扩展,同时增加了移动门户版功能及为AEAI ECP提供数据服务接 ...
- AEAI WM V1.5.0 升级说明,开源工作管理系统
1.升级说明 本次AEAI WM升级内容主要是针对数通畅联推出AEAI ECP企业云联平台而升级的,其中对AEAI WM的各模块进行扩展,同时增加了移动门户版功能及为AEAI ECP提供数据服务接口. ...
- 客户关系管理系统(CRM)的开发过程中使用到的开发工具总结
开发<客户关系管理系统(CRM)>软件过程,也就是一个标准的Winform程序的开发过程,我们可以通过这个典型的软件开发过程来了解目前的开发思路.开发理念,以及一些必要的高效率手段.本篇随 ...
- Winform开发框架之客户关系管理系统(CRM)的开发总结系列4-Tab控件页面的动态加载
在前面介绍的几篇关于CRM系统的开发随笔中,里面都整合了多个页面的功能,包括多文档界面,以及客户相关信息的页面展示,这个模块就是利用DevExpress控件的XtraTabPage控件的动态加载实现的 ...
- Winform开发框架之客户关系管理系统(CRM)的开发总结系列3-客户分类和配置管理实现
我在本系列随笔的开始,介绍了CRM系统一个重要的客户分类的展示界面,其中包含了从字典中加载分类.从已有数据中加载分类.以及分组列表中加载分类等方式的实现,以及可以动态对这些节点进行配置,实现客户分类的 ...
- Winform开发框架之客户关系管理系统(CRM)的开发总结系列2-基于框架的开发过程
在上篇随笔<Winform开发框架之客户关系管理系统(CRM)的开发总结系列1-界面功能展示>中介绍了我的整个CRM系统的概貌,本篇继续本系列的文章,介绍如何基于我的<winform ...
- Django CRM客户关系管理系统
CRM需求分析 随着信息化时代带来的科技创新,CRM客户关系管理系统带来的效益在已经成为很多企业提高竞争优势的一分部,CRM客户关系管理系统将企业管理和客户关系管理集成到统一的平台,其系统功能主要体现 ...
- CRM 客户关系管理系统
CRM(Customer Relationship Manager)客户关系管理系统 企业为提高核心竞争力,利用相应的信息技术以及互联网技术协调企业与顾客间在销售.营销和服务上的交互,从而提升其管理方 ...
随机推荐
- CSS Media媒体查询使用大全,完整媒体查询总结
前面的话 一说到响应式设计,肯定离不开媒体查询media.一般认为媒体查询是CSS3的新增内容,实际上CSS2已经存在了,CSS3新增了媒体属性和使用场景(IE8-浏览器不支持).本文将详细介绍媒体查 ...
- [Swift]LeetCode781. 森林中的兔子 | Rabbits in Forest
In a forest, each rabbit has some color. Some subset of rabbits (possibly all of them) tell you how ...
- Ubuntu 16.04下使用Eclipse:创建工程时卡死的解决方法
问题如下: Ubuntu 16.04下使用Eclipse创建工程时出现卡顿和卡死,新建一个MapReduce项目卡了一下午,鼠标变成了圆圈进度条转了一下午,还关不掉. 当我直接去关闭新建项目的窗口时, ...
- 【Spark篇】---SparkStream初始与应用
一.前述 SparkStreaming是流式处理框架,是Spark API的扩展,支持可扩展.高吞吐量.容错的实时数据流处理,实时数据的来源可以是:Kafka, Flume, Twitter, Zer ...
- Python内置函数(60)——staticmethod
英文文档: staticmethod(function) Return a static method for function. A static method does not receive a ...
- metasploit无法连接postgresql
注:倒数两条可以不做. 问题地址:https://askubuntu.com/questions/50621/cannot-connect-to-postgresql-on-port-5432 设置好 ...
- Jquery 对DOM 的操作
.focus 获取焦点 .blus离开焦点----------------------------------------------------------------------------- ...
- log4cplus使用(二)-自定义日志等级
log4cplus支持用户自定义日志等级,操作也比较简单,使用之前贴如下宏定义 #define LOG4CPLUS_MACRO_CREASH_LOG_LEVEL(pred) LOG4CPLUS_UNL ...
- 并发编程(十三)—— Java 线程池 实现原理与源码深度解析 之 Executors(三)
前两篇文章讲了线程池的源码分析,再来看这篇文章就比较简单了, 本文主要讲解 Executors 这个工具类,看看长江创建线程池的几种方法. newFixedThreadPool 生成一个固定大小的线程 ...
- 使用Spring Cloud搭建服务注册中心
我们在之前的博客中已经介绍过阿里的分布式服务框架dubbo[Linux上安装Zookeeper以及一些注意事项][一个简单的案例带你入门Dubbo分布式框架],但是小伙伴们应该也看到了,阿里的dubb ...