CRM项目总结

     一:开发背景

  在公司日益扩大的过程中,不可避免的会伴随着更多问题出现。

  对外 : 如何更好的管理客户与公司的关系?如何更及时的了解客户日益发展的需求变化?公司的产品是否真的符合客户需求?以及公司新产品信息是否更有针对性的及时推送给客户?客户没有

  对内 : 公司发展壮大,部门越来越多,如何明确每个部门的权限?如何合理的调配公司人员?如何合理的分配客户资源?如何精确的处理绩效考核?以及更重要的在销售管理中,如何更及时的了解是什么阻碍了公司的发展?是什么影响了销售的业绩?销售的服务是否让客户满意?

面对这么多的问题,这个时候就需要来一套完整的CRM就显得很有必要了。

 

二:开发周期

  1. 计划在两个月内完成项目的初步设计以及功能的初步实现。
  2. 基础功能完成后,会预留两个月时间来完成bug修复以及微调根据公司业务发展的业务需求。
  3. 项目上线后,开发人员持续跟进项目。根据公司业务发展和管理体系实时调整。

三:功能

 from django.db import models
 from rbac import models as rbac_model
 # Create your models here.

 class Department(models.Model):
     """
     部门表
     市场部     1000
     销售      1001
     """
     title = models.CharField(verbose_name='部门名称', max_length=16)
     code = models.IntegerField(verbose_name='部门编号',unique=True,null=False)

     def __str__(self):
         return self.title

 class UserInfo(models.Model):
     """
     员工表
     """
     auth = models.OneToOneField(verbose_name='用户权限', to=rbac_model.User,null=True,blank=True)
     name = models.CharField(verbose_name='员工姓名', max_length=16)
     username = models.CharField(verbose_name='用户名', max_length=32)
     password = models.CharField(verbose_name='密码', max_length=64)
     email = models.EmailField(verbose_name='邮箱', max_length=64)
     openid = models.CharField(verbose_name='微信唯一ID', max_length=64, null=True, blank=True)
     depart = models.ForeignKey(verbose_name='部门', to="Department",to_field="code")

     def __str__(self):
         return self.name

 class Course(models.Model):
     """
     课程表
     如:
         Linux基础
         Linux架构师
         Python自动化开发精英班
         Python自动化开发架构师班
     """
     name = models.CharField(verbose_name='课程名称', max_length=32)

     def __str__(self):
         return self.name

 class School(models.Model):
     """
     校区表

     """
     title = models.CharField(verbose_name='校区名称', max_length=32)

     def __str__(self):
         return self.title

 class ClassList(models.Model):
     """
     班级表
     如:
         烧饼  打饼班  1期  10000  2017-11-11  2018-5-11
     """
     school = models.ForeignKey(verbose_name='校区', to='School')
     course = models.ForeignKey(verbose_name='课程名称', to='Course')

     semester = models.IntegerField(verbose_name="班级(期)")
     price = models.IntegerField(verbose_name="学费")
     start_date = models.DateField(verbose_name="开班日期")
     graduate_date = models.DateField(verbose_name="结业日期", null=True, blank=True)
     memo = models.CharField(verbose_name='说明', max_length=256, blank=True, null=True, )
     teachers = models.ManyToManyField(verbose_name='任课老师', to='UserInfo', related_name='teach_classes',limit_choices_to={'depart_id__in':[1003,1004]})
     tutor = models.ForeignKey(verbose_name='班主任', to='UserInfo', related_name='classes',limit_choices_to={'depart_id':1002})

     def __str__(self):
         return "{0}({1}期)".format(self.course.name, self.semester)

 class Customer(models.Model):
     """
     客户表
     """
     qq = models.CharField(verbose_name='qq', max_length=64, unique=True, help_text='QQ号必须唯一')

     name = models.CharField(verbose_name='学生姓名', max_length=16)
     gender_choices = ((1, '男'), (2, '女'))
     gender = models.SmallIntegerField(verbose_name='性别', choices=gender_choices)

     education_choices = (
         (1, '重点大学'),
         (2, '普通本科'),
         (3, '独立院校'),
         (4, '民办本科'),
         (5, '大专'),
         (6, '民办专科'),
         (7, '高中'),
         (8, '其他')
     )
     education = models.IntegerField(verbose_name='学历', choices=education_choices, blank=True, null=True, )
     graduation_school = models.CharField(verbose_name='毕业学校', max_length=64, blank=True, null=True)
     major = models.CharField(verbose_name='所学专业', max_length=64, blank=True, null=True)

     experience_choices = [
         (1, '在校生'),
         (2, '应届毕业'),
         (3, '半年以内'),
         (4, '半年至一年'),
         (5, '一年至三年'),
         (6, '三年至五年'),
         (7, '五年以上'),
     ]
     experience = models.IntegerField(verbose_name='工作经验', blank=True, null=True, choices=experience_choices)
     work_status_choices = [
         (1, '在职'),
         (2, '无业')
     ]
     work_status = models.IntegerField(verbose_name="职业状态", choices=work_status_choices, default=1, blank=True,
                                       null=True)
     company = models.CharField(verbose_name="目前就职公司", max_length=64, blank=True, null=True)
     salary = models.CharField(verbose_name="当前薪资", max_length=64, blank=True, null=True)

     source_choices = [
         (1, "qq群"),
         (2, "内部转介绍"),
         (3, "官方网站"),
         (4, "百度推广"),
         (5, "360推广"),
         (6, "搜狗推广"),
         (7, "腾讯课堂"),
         (8, "广点通"),
         (9, "高校宣讲"),
         (10, "渠道代理"),
         (11, "51cto"),
         (12, "智汇推"),
         (13, "网盟"),
         (14, "DSP"),
         (15, "SEO"),
         (16, "其它"),
     ]
     source = models.SmallIntegerField('客户来源', choices=source_choices, default=1)
     referral_from = models.ForeignKey(
         'self',
         blank=True,
         null=True,
         verbose_name="转介绍自学员",
         help_text="若此客户是转介绍自内部学员,请在此处选择内部学员姓名",
         related_name="internal_referral"
     )
     course = models.ManyToManyField(verbose_name="咨询课程", to="Course")

     status_choices = [
         (1, "已报名"),
         (2, "未报名")
     ]
     status = models.IntegerField(
         verbose_name="状态",
         choices=status_choices,
         default=2,
         help_text=u"选择客户此时的状态"
     )
     consultant = models.ForeignKey(verbose_name="课程顾问", to='UserInfo', related_name='consultant',limit_choices_to={'depart_id':1005})
     date = models.DateField(verbose_name="咨询日期", auto_now_add=True)

     recv_date = models.DateField(verbose_name='接单时间',null=True,blank=True)

     last_consult_date = models.DateField(verbose_name="最后跟进日期", auto_now_add=True)

     def __str__(self):
         return "姓名:{0},QQ:{1}".format(self.name, self.qq, )

 class CustomerDistribution(models.Model):
     """客户分配表"""
     user = models.ForeignKey(verbose_name="当前客户顾问",to='UserInfo',limit_choices_to={'depart_id':1005},related_name="cds",null=True,blank=True)
     customer = models.ForeignKey(verbose_name="客户",to="Customer",related_name="dealers",null=True,blank=True)
     ctime = models.DateField(auto_now_add=True,null=True,blank=True)
     status_choices = (
         (1,'正在跟进'),
         (2,'已成单'),
         (3,'三天未跟进'),
         (4,'十五天未成单'),
     )
     status = models.IntegerField(verbose_name="状态",choices=status_choices,default=1)
     memo = models.CharField(verbose_name="更多信息",max_length=255,null=True,blank=True)

 class SaleRank(models.Model):
     """销售权重与分配"""
     user = models.ForeignKey(to="UserInfo",verbose_name='课程顾问',limit_choices_to={'depart':1005})
     num = models.IntegerField(verbose_name='数量')
     weight = models.IntegerField(verbose_name='权重')
     def __str__(self):
         return '权重:{0}												

CRM项目总结的更多相关文章

  1. 某CRM项目招投标工作的感悟

    最近参与了某公司的CRM项目招标工作, 由于此项目涉及到的二级单位比较多,以及项目金额比较大,所以此招标工作从准备到宣布中标一直持续了大概3个月时间,中间过程发生了一些颇有意思的事情,因为保密的原因无 ...

  2. CRM项目之RBAC权限组件-day26

    写在前面 上课第26天,打卡: 世间安得双全法 不负如来不负卿 s17day26 CRM项目 项目概要:XX公司CRM - 权限管理,公共组件,app ***** - 熟悉增删改查,Low *** - ...

  3. 读《31天学会CRM项目开发》记录2 - 企业信息管理系统

    在信息技术的快速推动下,企业如果依然利用传统的管理方式,以人为主,那效率便会大打折扣.在此背景下,企业信息化系统得 到了高速发展.如我们常见的ERP系统.MES系统,都是提高公司运行效率,降低运营以及 ...

  4. 读《31天学会CRM项目开发》记录1 - 认识软件开发

    今天闲来无事,心中又对软件开发充满了向往和憧憬.一直认为实践是检验真知的唯一标准,也是快速提升的绝密方法,是巩固基础加深基础的好去处.故在JD上搜了下软件开发,看到了这本<31天学会CRM项目开 ...

  5. crm项目整理

    crm项目整理   一.开发背景 由于公司人员的增多,原来通过excel表格存取方式过于繁琐,而且对于公司人员的调配和绩效考核等不能做到精确处理,所以开发crm系统,开始开发只是针对销售人员和客户,后 ...

  6. Linux下运行crm项目

    虚拟环境运行crm项目 1.进入虚拟环境 2.解决crm项目运行所需的依赖环境 1.手动解决 pip3 install django==1.11.14 pip3 install pymysql pip ...

  7. Django - CRM项目(2)Q查询(模糊查询)

    一.CRM项目(2) 利用Q查询中的q对象完成条件筛选功能. 批量删除.公户转私户功能. 新增一张跟进记录表ConsultRecord,迁移数据库并添加测试数据,实现跟进记录列表页面. 客户列表新增跟 ...

  8. crm项目整理概要

    一.开发背景 由于公司人员的增多,原来通过excel表格存取方式过于繁琐,而且对于公司人员的调配和绩效考核等不能做到精确处理,所以开发crm系统,开始开发只是针对销售人员和客户,后面陆续加上一些操作, ...

  9. Django - CRM项目(3)

    一.CRM项目的业务逻辑与表结构梳理 1.分析业务逻辑 (1) 引流(sem) (2) 网络咨询师(客服):添加客户信息和查看客户,分配销售 (3) 销售:查看私户 添加跟进记录 失败:加入公户 成功 ...

随机推荐

  1. Yahoo网站性能优化的34条军规

    1.尽量减少HTTP请求次数 终端用户响应的时间中,有80%用于下载各项内容,这部分时间包括下载页面中的图像.样式表.脚本.Flash等.通过减少页面中的元素可以减少HTTP请求的次数,这是提高网页速 ...

  2. Linux积累 命令之cat和wc

    cat主要有三大功能: 1.一次显示整个文件. $ cat   filename 2.从键盘创建一个文件. $ cat  >  filename 只能创建新文件,不能编辑已有文件. 3.将几个文 ...

  3. JS 中对变量类型的五种判断方法

    5种基本数据类型:undefined.null.boolean.unmber.string 复杂数据类型:object. object:array.function.date等 方法一:使用typeo ...

  4. Ext.chart.Chart 显示图标 -- 本地数据

    先来张直观的图,基于ext4.2制作 这就是弹出来的图表了. 今天先搭建一个本地数据版,也是静态数据版. 点击一个按钮执行一个function,来看function里面的东西: 一.依赖 Ext.re ...

  5. Java笔记 (持续更新ing)

    目录:  1 .  GC是什么,为什么要有GC? 1. GC是什么,为什么要有GC? GC是垃圾回收的意思,内存处理是编程人员容易出现问题的地方,忘记或者错误的内存回收会导致程序或系统的不稳定甚至崩溃 ...

  6. Replace Pioneer

    Replace Pioneer(官网:http://www.mind-pioneer.com)是一款专业的文本批量处理软件.仅仅要给定不论什么纯文本文件或文件列表.仅仅要准确设置转换规则.就能得到不论 ...

  7. POJ 1661 Help Jimmy(DP,注意边界)

    Help Jimmy Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 9399   Accepted: 3025 Descri ...

  8. BZOJ 1211 HNOI2004 树的计数 Prufer序列

    题目大意:给定一棵树中全部点的度数,求有多少种可能的树 Prufer序列.详细參考[HNOI2008]明明的烦恼 直接乘会爆long long,所以先把每一个数分解质因数.把质因数的次数相加相减.然后 ...

  9. 家居环境监測系统设计(PC上位机版)(手机APP版待定)

    下面是我的毕业设计:家居环境监測系统设计(PC上位机临时版.手机app版待定).本系统採用STC12C5A60S2单片机.结合传感器.分别对空气湿度.空气温度.气压.海拔.进水温度.出水温度.光照强度 ...

  10. 摧枯拉朽,说说ES6的三把火

    阅读目录 我是 Jser 我骄傲 作用域 模块系统 类(Class) 我是 Jser 我骄傲 JavaScript 如今可谓是屌丝逆袭高富帅的代名词哈,从当初闹着玩似的诞生到现在 Github 上力压 ...