crm项目-需求分析

###############  crm需求分析    ###############

 

讲师和学生:
1,批量生成上课记录,
2,考勤点名,
3,录入成绩,
4,显示成绩
5,上传作业,os模块,
6,下载成绩,

 

 

 

###############  crm需求分析    ###############

 

销售和客户
1,公共客户,
2,根据客户
3,绑定客户
4,取消绑定

 

 

 

###############  crm需求分析    ###############

"""
为什么开发这个crm?
我需要把这个作为一个通用的crm,
开发这个项目要解决企业的痛点
几个角色,销售,客户,检查员,老板,

解决一个销售人员的痛点:
1,聊得多了记不住
2,出现两个销售人员抢单的问题,
3,辞职了怎么办?客户都带走了,
需求:
1,存储客户信息,
2,办理报名手续,
3,跟进记录,一个客户需要跟进多次,所以是一个一对多的关系,需要分表
4,各种维度查询客户信息,

解决客户的管理的痛点:
1,客户要培训,考试,交试卷,要做阶段性的考核,检查,对客户进行管理,
2,最好是每一个客户的培训都有记录
3,每一个客户的业绩最后有问题,都是有原因的,
4,客户都是比较懒的,客户时间是不固定的,需要监督,需要考核
5,客户需要分等级,到的等级之后,可以给各种福利,
需求:
1,查询考核结果,以及排名
2,我的合同
3,我的推荐,推荐别人来加入,
6,投诉建议,

解决培训管理监督人员的痛点:
1,有一个评估
2,跟踪每一个客户的情况,看看客户的经营效果,
需求:
1,检查内容,检查结果批示,通报奖励和通报批评,
3,创建检查记录,考试记录,
4,查看成绩,考核结果,

解决老板的痛点:
1,有多少客户,客户的来源,分析这个来源是否产生了客户,是否还需要继续投入这个渠道,比如百度竞价排名,可以是招商,
2,每个客户业绩怎么样,
3,老板需要看报表,数据都是零散的,不利于分析,聚集起来就利于分析,就知道该往哪一个方向发展,
需求:
1,销售报表分析
2,管理质量分析,


"""

 

###############  考虑系统架构    ###############

"""
考虑系统架构

架构设计需要考虑的因素:
1,用户人群,是怎么样的,这个crm主要面对企业内部用户,所以对于各方面的要求不是很高,
页面不需要太炫,甚至安全程度也可以适当降低,公司一般要求越快开发出来越好,
2,用户量,针对企业内部用户量不多,如果是微博,每天上亿用户,用户量特别大,使用django就不合适了,
需要使用tornado,django天生就是做内容管理的,就是通过不同形式把内容展现出来,
这个crm就特别适合django做,微博会有高并发的问题,
3,业务场景,业务比较简单,就是页面点击什么,然后就从数据库查询就可以了,没有复杂的后端逻辑,就是增删改查,

用到的技术:
1,django
2,jQuery,本质就是对原生js的封装,
3,bootstrap

做完这个项目之后,涉及到数据的curd操作,你就都会了,直接就能用,
"""

 

###############  设计表结构    ###############

"""

需求分析完了,架构设计完成,下一步就是设计表结构,
大部分的交互都是和数据库交互,必须要确定好表结构,否则后续会出现问题,会有很多的坑,不断的出现坑,就填不过来了,
但是肯定会有问题,因为业务是复杂的,多变的,牛逼的开发,架构师,就能把路铺好,提前想到一些坑,

通用相关的表:
1,账号表,
2,角色表,
3,菜单表,

销售相关的表:
1,客户表:没有报名的是客户,报名的是学生,报名的学生要到报名表,
2,客户跟进表,
3,报名表,需要一个学生表,一个学生可能有多条报名信息,可以报多个课程,
4,缴费表,

管理监督相关的表:
1,课程表-----(相当于考核点一样,前台,管理,卫生,等,)这是固定的,
2,班级表-----(相当于是区域一样)
3,上课记录表,一个课程每天都要有记录,一对多的,-----(相当于是培训指导监督考核记录一样)
4,学习记录表,------(相当于培训指导监督考核的结果考核的最后等级一样)

这个东西有很多可以和erp相关的内容,

"""

 

 ###############  展示左侧菜单   ###############

"""
django自带后台admin的使用:
1,注册每个表,
2,创建超级管理员,用来登陆
3,登陆进去里面有user和group,这是django自带的,
4,你可以在user中,创建一个用户,然后登陆,是没有任何的权限的,
5,可以给新建的用户,添加权限,但是这个权限级别只能到表,不能到更具体的了,
6,对于表名,是显示的英文,但是你可以配置表的元信息来改变成为汉字,
7,我们可以使用django自带的认证系统,来创建自己的用户表,

##########################

我们要一个自己的系统,
需求:
1,每一个角色进去之后显示不一样的页面,
比如销售看到的客户表,是一个表格,
比如讲师看到的学员表,也是一个表格,

应该实现每一个人进去看到的是不一样的?
1,笨办法就是每一个表对应的页面都写一遍,但是这样会导致大量的代码冗余,
2,页面应该都是一个页面,只是说展示的数据不一样,然后不一样的部分进行定制化,
3,每一个人进去的菜单,都是动态的,这个菜单也可以使用一个页面,只是展示的菜单数据不同而已,
4,现在来实现前端的展示,前端可以使用bootstrap,可以使用他们提供的页面模板,

步骤:
1,创建一个base ,只保存css,js,等,可以把出去body的部分都放到base,
2,创建一个index,然后继承base,body放到这个index
3,创建static文件夹,放js,css等静态文件,


需求:
一个角色要显示哪些菜单,不同的角色进去,要显示不一样的菜单,要怎么做?
1,他能看到那些菜单,需要定义一下,而且这个数据需要在数据库存放,
2,url和角色怎么关联,肯定是数据库里面关联,crm_roles_menu,crm_roles,crm_menu这个角色和菜单是多对多的,
就是一个角色可以有多个菜单,菜单也可以有属于多个角色,url可以给url起一个别名,然后保存这个别名,
3,创建客户主页面,和销售人员主页面,然后继承index.html,
4,注意,user表中和role表是多对多的,

对于django自带的认证系统还是理解的不够深刻,
"""

 

 ###############  展示所有注册的表   ###############

"""

实现客户库-----客户列表页面
1,有列表
2,搜索
3,有过滤
4,有分页
5,有批量操作,

要做成一个通用的页面,每个页面不配置都一样,然后特殊的部分通过 配置来实现,
你把这个搞出来了,就相当于自己写了一个admin了,
我们可以做成一个模块,可以应用到别的项目,单独做成一个app,

分析url,就是admin/appname/tablename
通过url找到这个表名,这个可以使用反射来找到,就可以把表里面的数据取出来,
然后把数据放到页面,页面上就可以传什么表就展示什么表了,
这是基本的思路

代码怎么写?
首先第一步,先实现一个所有表的列表页面,
1,创建页面,table_index.html
2,继承base,把菜单的部分删除掉,保留单行条,
3,使用bootstrap的面板,上面是appname,下面是tablename,

现在最重要的是解决为什么一注册就展示了这个表,
思路就是创建了一个字典:
{appname:{tablename: tableadminclass,
            tablename: tableadminclass,
            },
appname:{tablename: tableadminclass,
            tablename: tableadminclass,
            },
}

怎么通过表名获取到modelclass,和app的名字呢?
1,model_class._meta.app_label
2,model_class._meta.model_name

怎么把admin_class 和model_class 进行关联呢?
admin_class.model = model_class 加了一个属性,利于前端调用,



"""

 

 ###############  展示客户列表页面   ###############

 

角色和需求
1,销售人员,
1.1,要对客户进行维护,可以对客户进行查看,新增,删除,修改,跟进等操作
代码上的要求:
增删查改各使用一个页面,然后根据每一个表的配置来控制,展示的字段,筛选字典,查询字段,批量操作,要求是可配置的,
1.2,最复杂的是客户查看页面,有查询,有筛选,有批量,有表头,有列表,有分页,
1.3,要有客户报名的业务,
1.4,客户池的概念,可以把没有成交可能的放入客户池,也可以把你认为有可能成交的客户拉入自己的名下,
2,讲师
1.1,要批量生成上课记录,对学生考勤
1.2,每天的作业成绩需要录入
3,学生
1.1,要交作业,
4,老板
要看报表,
5,登陆,注册,菜单展示,权限控制,

 

 

 ###############  展示客户列表页面   ###############

 

 ###############  展示客户列表页面   ###############

 

 ###############  展示客户列表页面   ###############

 

 ###############  展示客户列表页面   ###############

 

 ###############  展示客户列表页面   ###############

 

 ###############  展示客户列表页面   ############## #

 

你可能感兴趣的:(crm项目-需求分析)