客户关系管理系统数据库设计汇总.doc
客户关系管理系统的数据库设计
客户关系管理系统的数据库设计本篇论文目录导航:【题目】J2EE技术下的客户关系管理系统研究【第一章】J2EE技术在客户关系管理系统中的应用绪论【第二章】客户关系管理系统的相关技术及概念介绍【第三章】客户关系管理系统的需求分析及架构设计【4.1】客户关系管理系统的数据库设计【4.2】客户关系管理系统的相关模块设计【第五章】客户关系管理系统的详细设计及测试【结论/参考文献】基于J2EE技术的客户关系管理平台构建结论及参考文献第4 章系统概要设计及关键技术分析系统概要设计是包括对系统的数据库进行设计以及系统的模块和接口设计,通过这些设计将系统的整个轮廓勾勒了出来,搭出了系统的框架。
4.1 数据库设计4.1.1 角色权限设计基于J2EE技术的客户关系管理系统的角色权限设计部分的数据库设计如上图所示,采用的是基于角色的权限控制的策略而进行设计的。
基于J2EE 技术的客户关系管理系统的系统用户表是这一部分表的核心表,系统用户表包括基于J2EE 技术的客户关系管理系统的用户编号、用户名、密码、级别、终止期限、父用户编号、用户邮箱、用户概述、单位编号、用户姓名、工作、电话、RTX 号码、登陆标记等字段。
数据角色表包括角色编号、角色名称、角色描述、操作权限等四个字段。
单位表包括单位编码、上级单位编码、单位名称、单位代码、机构级别、成立日期、机关地址、单位人数、备注、序号等字段。
功能角色表则包括角色编号、角色名称、角色描述等三个字段,而系统功能模块表则包括了功能编号、父节点、功能名称、功能地址、排序吗、功能路径等字段。
在基于J2EE 技术的客户关系管理系统中,用户需要拥有与其功能角色对应的数据角色,因此,数据角色对应着操作权限,而功能角色对应着系统功能,通过这两个角色来对用户的权限进行管理。
4.1.2 销售信息库销售信息库中包括销售计划表、销售周报内容表、销售周报表、过期销售机会表、销售机会表、销售状态表、销售阶段表、销售状态-阶段变更记录表等八张表。
「客户关系管理系统数据库设计」
「客户关系管理系统数据库设计」
客户关系管理系统(Customer Relationship Management System,简称CRM)是一种通过整合企业所有客户相关信息,根据客户需求及行为进行有效管理和分析的系统。
它主要用于帮助企业建立和维护良好的客户关系,提高市场竞争力。
一个有效的CRM系统需要有一个良好的数据库设计作为其基础。
接下来是表结构的设计。
根据数据模型,可以将每个实体转化为一个数据表。
每个数据表包含多个字段,用于存储该实体的属性信息。
例如,客户表可以包含客户ID、客户名称、客户地址等字段。
每个字段的数据类型和约束条件需要根据实际需求进行设计。
最后是数据字典的设计。
数据字典是CRM系统数据库中各个字段的详细说明。
它包括字段名称、数据类型、约束条件、默认值等信息,以及对字段的解释和用途的描述。
数据字典可以帮助用户理解和使用CRM系统中的各个字段。
除了以上内容,还需要进行适当的索引设计、数据安全设计和性能优化等方面的工作,以确保CRM系统数据库的高效运行和安全性。
综上所述,一个完整的客户关系管理系统数据库设计包括数据模型设计、表结构设计、数据表关系设计和数据字典设计等内容。
通过良好的数据库设计,可以帮助企业构建一个高效、安全、易用的CRM系统,提升客户管理和市场竞争力。
客户关系管理系统数据库设计
客户关系管理系统一、数据库MyCrm1.系统用户表crm_User备注列名描述类型是否为空(F:不为空,T:为空)UserId 用户编号Int F 主键,标识,自动增长UserName 用户名Varchar(10) FUserPwd 用户密码Varchar(10) FRealName 真实姓名Varchar(50) FIsStatus 是否可用Int F 1为可用,0:不可用默认为1Email 注册邮箱Varchar(20) TAddress 联系地址Varchar(200) TTelPhone 联系电话Varchar(15) FRemarks 备注Varchar(200) TRoleId 角色编号Int F crm_Roles表外键DepartmentId 部门编号Int F crm_Department表外键2.角色表:crm_Roles备注列名描述类型是否为空(F:不为空,T:为空)RoleId 角色编号Int F 主键,标识,自动增长RoleName 角色名称Varchar(10) FIsStatus 是否可用Int F 1为可用,0:不可用默认为1 Remarks 备注Varchar(200) T3.部门表:crm_Department列名描述类型是否为空(F:不备注为空,T:为空)DepartmentId 部门编号Int F 主键,标识,自动增长DepartmentName 部门名称Varchar(10) FIsStatus 是否可用Int F 1为可用,0:不可用默认为1 Remarks 备注Varchar(200) T4.客户表:crm_Customers备注列名描述类型是否为空(F:不为空,T:为空)CustomerId 客户编号Int F 主键,标识,自动增长CustomerName 客户姓名varchar(50) FUserID 归属用户Int F 用户表外键Company 所属公司名称Varchar(100) TCustomerPost 职务Varchar(20) FEmail 联系邮箱Varchar(20) TAddress 联系地址Varchar(200) TTelPhone 联系电话Varchar(15) FCutomerGrade 客户重要等级Int F 123451最重要,依次递减CutomerCity 客户所在城市VarChar(50) FRemarks 备注Varchar(200) TIsStatus 是否可用Int F 1为可用,0:不可用默认为1二.功能需求1.角色分为:系统超级管理员,部门经理,普通员工三个等级2.系统中所有的用户只可以修改本人密码,员工的部门、角色只有管理员可以修改,系统管理员可以修改全部人员的密码3.角色功能:1):系统超级管理员具有管理用户功能:可以添加、修改、停用用户、重置用户密码。
CRM客户关系管理数据库设计文档
负责客户的经理名称, 非空
cust_level
number(2)
客户等级, 参照数据字典表。
cust_satisfy
number(2)
客户满意度, 参照数据字典表。
cust_credit
number(2)
客户信誉度,参照数据字典表 。
cust_address
varchar2(100)
字段名称
字段类型
字段备注
prod_no
number(10)
商品编号,主键, 非空
prod_name
varchar2(300)
商品名称, 非空
prod_type
varchar2(400)
商品型号, 非空
prod_garde_batch
varchar2(300)
商品等级/ 批次, 非空
prod_unit
varchar2(500)
流失原因
lost_status
number(2)
客户流失状态(0:预警/1:暂缓流失/2:确认流失) , 非空
8.交往记录表(communicate_record)
字段名称
字段类型
字段备注
comm_no
varchar2(20)
交往记录编号,主键, 非空
comm_cust_no
cust_corporation
varchar2(50)
客户法人。
cust_registered_capital
nvarchar2(35)
客户注册资金(万元)
cust_turnover
nvarchar2(35)
客户年营业额(万元)
cust_bank
客户关系管理系统数据库关系方案设计书文档56442
联系人性别
Lkm_postion
Not null
Text
NVARCHAR(50)
联系人地址
Lkm_tel
null
Text
NVARCHAR(50)
联系人办公室电话
Lkm_mobile
Not null
Text
NVARCHAR(50)
联系人手机
Lkm_memo
Not null
Text
Not null
Number
Bigint
产品编号
Stk_warehouse
Not null
Text
Nvarchar(50)
库房
Stk_ware
Not null
Text
Nvarchar(50)
库位
Stk_count
Not null
Number
Int
库存数量
Stk_memo
Not null
Number
money
Che_create_by
Not null
Text
NVARCHAR(50)
机会创建人
Chc_due_id
Not null
Text
bigint
被指派人的编号
Chc_due_to
Not null
Text
NVARCHAR(50)
被指派人
Chc_due_date
Not null
Text
datetime
指派日期
Not null
Text
Char(17)
客户编号
Odr_customer
Not null
Text
NVARCHAR(100)
CRM客户关系管理数据库设计文档
varchar2(50)
客户法人。
cust_registered_capital
nvarchar2(35)
客户注册资金(万元)
cust_turnover
nvarchar2(35)
客户年营业额(万元)
cust_bank
varchar2(50)
客户开户银行。
cust_bank_account
字段名称
字段类型
字段备注
link_no
varchar2(20)
联系人编号,主键, 非空
link_cust_no
varchar2(20)
客户编号,外键, 非空
link_name
varchar2(50)
联系人名称, 非空
link_sex
number(2)
联系人性别(0:男/1:女)。
link_position
varchar2(500)
流失原因
lost_status
number(2)
客户流失状态(0:预警/1:暂缓流失/2:确认流失) , 非空
8.交往记录表(communicate_record)
字段名称
字段类型
字段备注
_no
varchar2(20)
交往记录编号,主键, 非空
comm_cust_no
varchar2(50)
客户银行账号。
cust_local_tax_no
varchar2(50)
客户地税登记号
cust_national_tax_no
varchar2(50)
客户国税登记号
cust_flag
number(2)
客户标识(0:已删除/1:正常/2:流失), 非空
[全]项目:客户管理系统数据库设计
1.客户信息表
名称
类型
描述
Id
Int
CustomerNo
Int
序号(唯一)
AddDate
datetime
录入日期
MidDate
datetime
最近修改日期
CompanyName
varchar(50)
公司名称
CTId
Int
客户信息级别ID
PTId
varchar(50)
合同编号
TId
Int
合同状态ID(外键)
CustomerNo
Int
公司序号
SignedDate
datetime
签订时间
ExpDate
datetime
到期时间
ContractPrice
decimal(18, 0)
合同金额
BPId
Int
业务人员ID
FirstPrice
decimal(18, 0)
首付金额
项目类别ID
ProjectName
varchar(50)
项目名称
Url
varchar(50)
网址
LinkMan
varchar(50)
联系人
Phone
varchar(50)
座机
Mobile
varchar(50)
手机
Fax
varchar(50)
传真
varchar(50)
邮箱
Address
varchar(100)
datetime
录入日期
Mobile
varchar(50)
[全]项目:客户管理系统数据库设计
ServiceEndDate
datetime
服务结束日期
Remark
varchar(50)
备注
7.合同信息级别表
名称
类型
描述
TId
Int
Name
varchar(20)
合同信息级别名称
8.业务员信息表
名称
类型
描述
BPId
Int
Name
varchar(50)
姓名
Sex
Char
性别
AddDate
PayAllDate
datetime
全款支付日期
ServiceStartDate
datetime
服务开始日期
ServiceEndDate
datetime
服务结束日期
Remark
varchar(50)
备注
6.续费信息表
名称
类型
描述
Id
Int
No
Int
序号(唯一)
AddDate
datetime
录入日期
ContractNum
地址(省、市、具体)
2.客户信息级别表
名称
类型
描述
CTId
Int
Name
varchar(20)
客户信息级别名称
3.项目类别信息表
名称
类型
描述
PTId
Int
TypeName
varchar(20)
项目类别名称
4.洽谈记录表
名称
类型
描述
Id
Int
CustomerNo
int
客户序号
DiscussionTopic
CRM客户关系管理数据库设计文档
varchar2(50)
客户法人。
cust_registered_capital
nvarchar2(35)
) (万元客户注册资金
cust_turnover
nvarchar2(35)
) (万元客户年营业额
cust_bank
varchar2(50)
客户开户银行。
cust_bank_account
varchar2(50)
,负责客户的经理名称非空
lost_last_order_date
varchar2(50)
客户上次下订单时间,非空
lost_last _date
varchar2(50)
确认客户流失时间
lost_delay
varchar2(500)
暂缓措施
lost_reson
varchar2(500)
varchar2(50)
联系人职位。
link_telephone
varchar2(50)
联系人办公电话。
link_mobile
number(11)
联系人手机号码
link_remark
varchar2(400)
联系人备注
link_flag
number(2)
非空,未删除)/1:已删除0:联系人标识(
(orders)订单表3.
字段名称
字段类型
字段备注
orde_no
number(10)
,订单编号,主键非空
orde_cust_no
varchar2(20)
,客户编号,外键非空
orde_date
varchar2(50)
订单日期非空,
客户关系管理系统数据库设计
系统名称:客户关系管理系统一、系统需求分析:客户管理系统是为了方便管理客户基本信息,完成公司决策的重要手段,通过该系统,系统管理员可以通过次系统查询客户的基本信息,以及客户所购产品的信息。
并可以对新老客户进行添加和删除,也可对现有用户的基本信息进行更改。
从而实现公司对其客户的管理。
客户可以通过该数据库查看自己的基本信息和消费情况。
职员可以通过该数据库查看自己的基本情况、业绩情况和工作计划。
该数据库包含5个实体,分别是客户,联系人,产品,任务计划,反馈信息。
通过该数据库,可以实现以下功能(举例)简单查询:①查询客户的基本信息②查询公司职员的业绩情况(即联系人发展的客户情况)③查询公司职员的任务计划复杂查询:①查询客户对某一类型产品的反馈信息(通过产品表和反馈信息表连接实现)②查询客户反馈信息的受理情况插入功能:增添新客户,新产品,新联系人,新反馈信息以及其相关属性修改功能:系统管理员修改客户的基本信息(如积分,联系方式等),修改联系人的工作计划,反馈信息的受理情况二、E-R 图n n1 n 1 n11三、关系模式 系统中的实体有:客户,联系人,反馈信息,任务计划,产品 关系模式如下: 客户(客户编号,姓名,联系方式,联系地址,积分,信用度,所购产品,消费时间,联系人编号) 联系人(联系人编号,姓名,所属部门,产品类型,任务计划编号,工资) 反馈信息(反馈编号,反馈人姓名,反馈时间,反馈内容,产品编号,解决情况) 任务计划(任务计划编号,联系人编号,客户数量,计划利润,计划时间,实施情况)产品(产品编号,产品名称,生产日期,产品类型,质量级别,价格,优惠购买 购买数购买时客户编产品编客户编反馈 反馈编发展 联系人编号 客户编客户 联系人 反馈信产品 任务计联系人编号 所购产品 编号 购买 反发展制定 信用度 姓名所属部姓名 工资 客户编号 联系方式联系地址 积分 产品类型 工作计划编号 产品类质量级优惠情名称 生产日编号 产品价内容 反馈时间 反馈者 反馈编号 解决情况 产品编号 编号客户数计划利润 计划时间 实施情况职工编消费时间 任务计划联系人编号制定时情况)反馈(客户编号,反馈编号)发展(联系人编号,客户编号)购买(客户编号,产品编号,购买时间,购买数量)制定(联系人编号,任务计划编号,制定时间)四,物理设计客户表结构客户编号Char(10主键)姓名Char(8) Not null联系方式Char(12)积分Char(8) Check约束,在0到100内取整信用度Char(8) Check约束,在0到100内取整Not null所购产品Char(20)消费时间datetimNot nulle联系地址Char(10反馈信息表结构反馈编号Int 主键,identity(1,1)反馈人姓名Char(8 )反馈时间DatetimeNot null反馈内容Char(200) Not null)联系人编号Char(10)外键联系人表结构联系人编号Char(10)主键姓名Char(8) Not null 所属部门Char(10)Not null产品类型Char(20) Check'电器','化妆品','炊具'任务计划编号Char(10)外键工资Char(10)Not null产品编号Char(10)Not null解决情况Char(8) Default 缺省值为“否”任务计划表结构任务计划编号Char(10)主键联系人编号Char(10)Not null客户数量Char(20)Not null计划利润Char(20)Not null计划时间DatetimeNot null实施情况Char(2) Default 缺省值为“否”产品表结构产品编号Char(10)主键产品名称Char(2Not null0)产品价格Char(10)Not null产品类型Char(10) Chec约束,取'电器','化妆品','炊具之一'生产日期DatetimeNot null质量级别Char(8) Check约束,取A,B ,C,D,E 之一优惠情况Char(10)反馈联系表结构反馈编号Char(10) Not null客户编号Char(10) Not null制定联系表结构工作计划编号Char(10)Notnull联系人编号Char(10) Not null制定时间datetime Not null购买关系表结构客户编号Char(10) Not null产品编号Char(10) Not null购买时间datetime Not null购买数量Char(20) Not null发展关系表结构联系人编号Char(10)Notnull客户编号Char(10) Not null五,系统实现1.数据库及其基本表的建立数据库的建立:create database CustomerMSon(name='客户关系管理系统',filename='d:\DAI\客户关系管理系统.mdf', size=10mb,maxsize=20mb,filegrowth=1mb)log on(name='客户关系管理系统',filename='d:\DAI\客户关系管理系统.ldf', size=10mb,maxsize=20mb,filegrowth=1mb)建立基本表:use CustomerMScreate table 任务计划(任务计划编号 char(10) primary key,联系人编号 char(10) not null,计划利润 char(20) not null,计划时间 datetime not null,实施情况 char(2) default('否'))create table 联系人(联系人编号 char(10) primary key,姓名 char(8) not null,所属部门 char(10) not null,产品类型 char(20) check(产品类型 in('电器','化妆品','炊具')),任务计划编号 char(10) references 任务计划(任务计划编号), 工资 char(10) not null)create table 客户(客户编号 char(10) PRIMARY KEY,姓名 char(8) not null,联系方式 char(12),积分 char(8) check(积分 between '0 'and '100'),信用度 char(8) check(信用度 between 0 and 100),消费时间 datetime not null,联系地址 char(10),联系人编号 char(10) references 联系人(联系人编号))create table 反馈信息(反馈编号 int primary key identity(1,1),反馈人姓名 char(8),反馈时间 datetime not null,反馈内容 char(200) not null,产品编号 char(8) not null,解决情况 char(8) default('否'))create table 产品(产品编号 char(10) primary key,产品名称 char(20) not null,产品价格 char(10) not null,产品类型 char(10) check(产品类型 in('电器','化妆品','炊具')),生产日期 datetime not null,质量级别 char(8) check(质量级别 in('A','B','C','D','E')), 优惠情况 char(10))create table 反馈(反馈编号 int identity(1,1),客户编号 char(10) not null)create table 制定(工作计划编号 char(10) not null,联系人编号 char(10) not null,制定时间 datetime not null)create table 购买(客户编号 char(10) not null,产品编号 char(10) not null,购买时间 datetime not null,购买数量 char(20) not null)create table 发展(联系人编号 char(10) not null,客户编号 char(10) not null)2、创建视图1.客户视图(客户编号,姓名,联系方式,联系地址,积分,信用度,所购产品,消费时间,联系人姓名,产品名称,生产日期,产品类型,质量级别,价格, 解决情况反馈内容)代码如下:Create view 客户视图AsSelect 客户.客户编号,客户.姓名,客户.联系方式,客户.积分,客户.信用度,客户.所购产品,客户.消费时间,联系人.姓名 as "联系人姓名",产品.产品名称,产品.生产日期,产品.产品类型,产品.质量级别,产品.产品价格,反馈信息.解决情况, 反馈信息.反馈内容From 客户 join 产品 On 客户.所购产品=产品.产品名称Join 联系人 On 客户.联系人编号=联系人.联系人编号Join 反馈信息 on 客户.姓名=反馈信息.反馈人姓名2.职工视图(联系人编号,姓名,所属部门,产品类型,任务计划编号,工资,姓名,联系方式,联系地址,任务计划编号,计划利润,计划时间,实施情况)代码如下:Create view 职工视图AsSelect 联系人.联系人编号,联系人.姓名,联系人.所属部门,联系人.产品类型,联系人.工资,客户.姓名 as "客户姓名",客户.联系方式,客户.联系地址,任务计划.任务计划编号,任务计划.计划利润,任务计划.计划时间,任务计划.实施情况From 联系人 join 客户 on 联系人.联系人编号=客户.联系人编号Join 任务计划 on 联系人. 任务计划编号=任务计划.任务计划编号3、创建索引客户(在客户表中客户编号列建立索引)Create index 客户 on 客户(客户编号)产品(在产品表上产品编号列建立索引)Create index 产品 on 产品(产品编号)4、存储过程的创建①简单查询:1 查询客户的基本信息Create procedure Scustomer @name char(8)AsSelect *from 客户Where 客户.姓名=@name2查询公司职员的业绩情况(即联系人发展的客户情况)Create procedure workerperformance @workercode char(10)AsSelect "total"=count(客户.客户编号 )From 客户 join 联系人 on 客户.联系人编号=联系人.联系人编号Where 联系人.联系人编号=@workercode3查询公司职员的任务计划Create procedure 查询任务计划 @work char(8)AsSelect *from 任务计划Where 任务计划.联系人编号=@work②复杂查询:1查询客户对某一类型产品的反馈信息(通过产品表和反馈信息表连接实现)Create procedure 查询反馈信息 @productcode char(8)AsSelect 产品.产品类型,反馈信息.反馈内容From 产品 Join 反馈信息 on 产品.产品编号=反馈信息.产品编号Where 产品.产品类型=@productcode2查询客户反馈信息的受理情况Create procedure 反馈信息受理@customercode char(8) ,@customername char(20)AsSelect 客户.姓名,客户.客户编号,反馈信息.解决情况From 客户 Join 反馈信息 on 客户.姓名=反馈信息.反馈人姓名Where 客户.客户编号=@customercode and 客户.姓名=@customername③插入功能:增添新客户,新产品,新联系人,新反馈信息以及其相关属性增添新用户:Create procedure insertcustomer @客户编号char(10),@姓名char(20),@联系方式 char(20),@联系地址 char(20),@积分 char(10),@信用度 char(10),@所购产品 char(20),@消费时间 datetime,@联系人编号char(10)AsInsert into 客户 values(@客户编号,@姓名,@联系方式,@联系地址,@积分,@信用度,@所购产品,@消费时间,@联系人编号)③修改功能:系统管理员修改客户的基本信息(如积分,联系方式等),修改联系人的工作计划,反馈信息的受理情况修改客户的基本信息(例:给特定客户增加积分)Create procedure addmarks @mark char(10),@customercode char(10) AsUpdate 客户set 客户.积分=客户.积分+@markWhere(客户.客户编号=@customercode)5.创建触发器客户的信用度取在0到100之间,当对信用度进行更新操作时,执行触发器Create trigger creditOn 客户For updateAsDeclare @total intSelect @total=信用度From 客户If(@total>100)BeginPrint '信用度不能超过100'Rollback transactionEndReturn完成日期:年月日。
090307天意电脑公司客户关系管理系统数据库设计
天意电脑公司客户关系管理系统(二)系统功能需求1.系统总体功能描述本系统为企业提供一个有效的客户关系管理平台,操作要求尽量简单、高效。
本系统将有助于企业改善对现有客户的管理状态,加强企业与客户的联系。
分析本系统应提供给系统参与者如下的功能操作:管理客户的基本信息,记录客户发生的销售信息,根据客户的销售额的不同,将客户划分级别;分析客户分布的区域和来源方式。
为了满足上面提出的功能需求,本系统应实现以下功能:(1)区域信息管理功能:管理客户所在的区域信息,可以进行增删改查操作.(2)客户资料管理功能:用于管理客户的基本信息,以便了解天意电脑公司的客户资料。
(3)公司信息管理功能:用于管理本公司基本信息,包括公司的法人、性质等。
(4)联系人信息管理功能:用于管理联系人基本信息,以便管理员了解联系人的情况和联系人自己查询自己的基本信息。
(5)销售信息管理功能:提供了管理员管理销售信息的功能,记录企业与客户之间发生的每一次业务往来。
(6)产品信息管理功能:对天意电脑公司的产品进行管理。
(7)客户区域分析功能:提供了分析客户所在地的区域分布情况,从而了解客户在各个省份的分布情况。
(8)客户来源分析功能:提供了将客户按照客户来源方式分类分析的功能,从而掌握客户是从网络、发布会或是其他方式获得的。
(10)客户级别分析功能:把客户按照销售成交额划分级别,体现客户的重要程度。
(11)用户信息管理功能:提供了管理员对用户的管理和查询的功能。
2.识别参与者对于平台功能需求的分析,我们定位了三种参与者:超级管理员、普通用户、联系人。
现对参与者描述如下:(1)管理员描述:负责整个系统中所有模块的管理工作,拥有最高的权限。
用于整个系统的增删改以及维护工作。
可以进行区域信息管理、客户资料管理、公司信息管理、联系人信息管理、销售信息管理、产品管理、客户来源分析、客户级别分析、客户区域分析、用户管理、更改密码、设置权限、帮助。
(2)用户描述:可以查询区域信息、客户资料、公司信息、联系人信息、销售信息、产品信息,进行客户来源分析、客户级别分析、客户区域分析,更改自己的密码以及帮助。
CRM客户关系管理数据库设计文档
number(2)
库存标识(0:已删除/I:未删除),非空
7.客户流失表(cust lost)
字段名称
字段类型
字段备注
lost_no
number(10)
客户流失编号,主键,非空
lost_cust_no
varchar2(
20)
客户编号,外键,非空
lost_manager_n
varchar2(I
00)
数据字典标题,非空
basi_value
varchar2(I
00)
数据字典内容,非空
basi editable
number(2)
数据字典可编辑状态(0/1),非空
basi_flag
number(2)
数据字典标识(0:已删除/I:未删除),非 空
10•服务管理表(service manager)
varchar2(
50)
权限名称
right_url
varchar2(
100)
权限链接地址
right_tip
varchar2(
50-
显不
16.角色-权限表(sys role right)
字段名称
字段类型
备注
rf role id
number(8)
角色编号,外键,非空
rf_right_code
varchar2(
ame
varchar2(
50)
负责客户的经理名称,非空
lost_last_orde
r date
varchar2(
50)
客户上次下订单时间,非空
lost_last _date
varchar2(
客户关系管理系统数据库关系设计文档
{ 项目名称} 数据库设计文档微软教育襄樊软件学院版本历史目录0. 文档介绍 (3)0.1文档目的 (3)0.2文档范围 (3)0.3读者对象 (3)0.4参考文献 ........................................................................................ 错误!未定义书签。
0.5术语与缩写解释 (4)1. 数据库环境说明 (5)2. 数据库的命名规则 (6)3. 逻辑设计 (6)4. 物理设计 (6)4.0表汇总 (6)4.1表A (8)4.N 表N .......................................................................................................... 90.文档介绍0.1 文档目的数据库设计文挡是数据库文件系统的详细数据库详细设计说明,主要用于规范数据库的实体字段,和实体的功能性解释说明0.2 文档范围文挡要求数据库使用sqlserver2000\2005来开发, 文挡主要包括数据库实体和每个实体的字段的详细设计和说明,并且用word文件方式呈现0.3 读者对象项目开发小组;项目验收人员0.4 术语与缩写解释1. 数据库环境说明软件环境说明:数据库要使用sql server2000或者是sql server2005来开发,要求,数据库实体的命名与数据库设计文挡的一致,字段与数据库详细设计文挡的一致,命名简洁规范,易于读取;2. 数据库的命名规则数据库命名规则主要是采用英文字母加下划线来命名;●如果实体用一个单词能表达清楚的话,该实体只用一个单词命名,如实体库存表,命名规则为:storage●如果实体需要用多个单词来拼接,主要是单词的缩写加下画线来命名该实体;如实体系统用户:命名规则为:sys_users3. 逻辑设计提示:数据库设计人员根据需求文档,创建与数据库相关的那部分实体关系图(ERD)。
CRM客户关系管理数据库设计文档
15•权限表(sys right)
字段名称
字段类型
备注
right_code
varchar2(
50)
权限编号,主键,非空
right_parent_c
ode
varchar2(
50)
权限父节点名称
right_type
varchar2(
20)
权限类型
right_text
ame
varchar2(
50)
负责客户的经理名称,非空
lost_last_orde
r date
varchar2(
50)
客户上次下订单时间,非空
lost_last _date
varchar2(
50)
确认客户流失时间
lost delay
varchar2(
暂缓措施
500)
lost_reson
varchar2(
13.用户表(sys user)
字段名称
字段类型
备注
user id
number(8)
用户编号,主键,非空
user_role_id
number(20
)
角色编号,外键,非空
user_name
varchar2(
50)
用户名称,非空
user_password
varchar2(
50)
用户密码,非空
user flag
2.联系人表(cust1inkman)
字段名称
字段类型
字段备注
link_no
varchar2(
20)
联系人编号,主键,非空
link_cust_no
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
系统名称:客户关系管理系统一、系统需求分析:客户管理系统是为了方便管理客户基本信息,完成公司决策的重要手段,通过该系统,系统管理员可以通过次系统查询客户的基本信息,以及客户所购产品的信息。
并可以对新老客户进行添加和删除,也可对现有用户的基本信息进行更改。
从而实现公司对其客户的管理。
客户可以通过该数据库查看自己的基本信息和消费情况。
职员可以通过该数据库查看自己的基本情况、业绩情况和工作计划。
该数据库包含5个实体,分别是客户,联系人,产品,任务计划,反馈信息。
通过该数据库,可以实现以下功能(举例)简单查询:①查询客户的基本信息②查询公司职员的业绩情况(即联系人发展的客户情况)③查询公司职员的任务计划复杂查询:①查询客户对某一类型产品的反馈信息(通过产品表和反馈信息表连接实现)②查询客户反馈信息的受理情况插入功能:增添新客户,新产品,新联系人,新反馈信息以及其相关属性修改功能:系统管理员修改客户的基本信息(如积分,联系方式等),修改联系人的工作计划,反馈信息的受理情况二、E-R图三、关系模式系统中的实体有:客户,联系人,反馈信息,任务计划,产品关系模式如下:客户(客户编号,姓名,联系方式,联系地址,积分,信用度,所购产品,消费时间,联系人编号)联系人(联系人编号,姓名,所属部门,产品类型,任务计划编号,工资)反馈信息(反馈编号,反馈人姓名,反馈时间,反馈内容,产品编号,解决情况)任务计划(任务计划编号,联系人编号,客户数量,计划利润,计划时间,实施情况)产品(产品编号,产品名称,生产日期,产品类型,质量级别,价格,优惠情况)反馈(客户编号,反馈编号)发展(联系人编号,客户编号)购买(客户编号,产品编号,购买时间,购买数量)制定(联系人编号,任务计划编号,制定时间)四,物理设计五,系统实现1.数据库及其基本表的建立数据库的建立:create database CustomerMSon(name='客户关系管理系统',filename='d:\DAI\客户关系管理系统.mdf',size=10mb,maxsize=20mb,filegrowth=1mb)log on(name='客户关系管理系统',filename='d:\DAI\客户关系管理系统.ldf',size=10mb,maxsize=20mb,filegrowth=1mb)建立基本表:use CustomerMScreate table 任务计划(任务计划编号char(10) primary key,联系人编号char(10) not null,客户数量char(20) not null,计划利润char(20) not null,计划时间datetime not null,实施情况char(2) default('否'))create table 联系人(联系人编号char(10) primary key,姓名char(8) not null,所属部门char(10) not null,产品类型char(20) check(产品类型in('电器','化妆品','炊具')),任务计划编号char(10) references 任务计划(任务计划编号),工资char(10) not null)create table 客户(客户编号char(10) PRIMARY KEY,姓名char(8) not null,联系方式char(12),积分char(8) check(积分between '0 'and '100'),信用度char(8) check(信用度between 0 and 100),所购产品char(20) not null,消费时间datetime not null,联系地址char(10),联系人编号char(10) references 联系人(联系人编号))create table 反馈信息(反馈编号int primary key identity(1,1),反馈人姓名char(8),反馈时间datetime not null,反馈内容char(200) not null,产品编号char(8) not null,解决情况char(8) default('否'))create table 产品(产品编号char(10) primary key,产品名称char(20) not null,产品价格char(10) not null,产品类型char(10) check(产品类型in('电器','化妆品','炊具')), 生产日期datetime not null,质量级别char(8) check(质量级别in('A','B','C','D','E')),优惠情况char(10))create table 反馈(反馈编号int identity(1,1),客户编号char(10) not null)create table 制定(工作计划编号char(10) not null,联系人编号char(10) not null,制定时间datetime not null)create table 购买(客户编号char(10) not null,产品编号char(10) not null,购买时间datetime not null,购买数量char(20) not null)create table 发展(联系人编号char(10) not null,客户编号char(10) not null)2、创建视图1.客户视图(客户编号,姓名,联系方式,联系地址,积分,信用度,所购产品,消费时间,联系人姓名,产品名称,生产日期,产品类型,质量级别,价格, 解决情况反馈内容)代码如下:Create view 客户视图AsSelect 客户.客户编号,客户.姓名,客户.联系方式,客户.积分,客户.信用度,客户.所购产品,客户.消费时间,联系人.姓名 as "联系人姓名",产品.产品名称,产品.生产日期,产品.产品类型,产品.质量级别,产品.产品价格,反馈信息.解决情况, 反馈信息.反馈内容From 客户 join 产品 On 客户.所购产品=产品.产品名称Join 联系人 On 客户.联系人编号=联系人.联系人编号Join 反馈信息 on 客户.姓名=反馈信息.反馈人姓名2.职工视图(联系人编号,姓名,所属部门,产品类型,任务计划编号,工资,姓名,联系方式,联系地址,任务计划编号,计划利润,计划时间,实施情况)代码如下:Create view 职工视图AsSelect 联系人.联系人编号,联系人.姓名,联系人.所属部门,联系人.产品类型,联系人.工资,客户.姓名as "客户姓名",客户.联系方式,客户.联系地址,任务计划.任务计划编号,任务计划.计划利润,任务计划.计划时间,任务计划.实施情况From 联系人join 客户on 联系人.联系人编号=客户.联系人编号Join 任务计划on 联系人. 任务计划编号=任务计划.任务计划编号3、创建索引客户(在客户表中客户编号列建立索引)Create index 客户 on 客户(客户编号)产品(在产品表上产品编号列建立索引)Create index 产品 on 产品(产品编号)4、存储过程的创建①简单查询:1 查询客户的基本信息Create procedure Scustomer @name char(8)AsSelect *from 客户Where 客户.姓名=@name2查询公司职员的业绩情况(即联系人发展的客户情况)Create procedure workerperformance @workercode char(10)AsSelect "total"=count(客户.客户编号)From 客户join 联系人on 客户.联系人编号=联系人.联系人编号Where 联系人.联系人编号=@workercode3查询公司职员的任务计划Create procedure 查询任务计划@work char(8)AsSelect *from 任务计划Where 任务计划.联系人编号=@work②复杂查询:1查询客户对某一类型产品的反馈信息(通过产品表和反馈信息表连接实现)Create procedure 查询反馈信息@productcode char(8)AsSelect 产品.产品类型,反馈信息.反馈内容From 产品Join 反馈信息on 产品.产品编号=反馈信息.产品编号Where 产品.产品类型=@productcode2查询客户反馈信息的受理情况Create procedure 反馈信息受理@customercode char(8) ,@customername char(20) AsSelect 客户.姓名,客户.客户编号,反馈信息.解决情况From 客户Join 反馈信息on 客户.姓名=反馈信息.反馈人姓名Where 客户.客户编号=@customercode and 客户.姓名=@customername③插入功能:增添新客户,新产品,新联系人,新反馈信息以及其相关属性增添新用户:Create procedure insertcustomer @客户编号char(10),@姓名char(20),@联系方式char(20),@联系地址char(20),@积分char(10),@信用度char(10),@所购产品char(20),@消费时间datetime,@联系人编号char(10)AsInsert into 客户values(@客户编号,@姓名,@联系方式,@联系地址,@积分,@信用度,@所购产品,@消费时间,@联系人编号)③修改功能:系统管理员修改客户的基本信息(如积分,联系方式等),修改联系人的工作计划,反馈信息的受理情况修改客户的基本信息(例:给特定客户增加积分)Create procedure addmarks @mark char(10),@customercode char(10)AsUpdate 客户set 客户.积分=客户.积分+@markWhere(客户.客户编号=@customercode)5.创建触发器客户的信用度取在0到100之间,当对信用度进行更新操作时,执行触发器Create trigger creditOn 客户For updateAsDeclare @total intSelect @total=信用度From 客户If(@total>100)BeginPrint '信用度不能超过100'Rollback transactionEndReturn完成日期:年月日。