0

0

如何在mysql中设计简单CRM系统_mysql CRM系统项目实战

P粉602998670

P粉602998670

发布时间:2025-11-18 13:10:03

|

900人浏览过

|

来源于php中文网

原创

crm系统核心功能模块包括客户管理、联系记录、销售阶段跟踪和用户权限。1. 客户管理:存储客户基本信息,如姓名、公司、联系方式,并通过owner_id关联负责的销售人员;2. 联系记录:在interactions表中保存每次沟通的时间、方式和内容,确保可追溯;3. 销售机会跟踪:opportunities表管理潜在客户的转化过程,支持多阶段(如初步接触、报价、成交)及金额和预计关闭日期的记录;4. 用户账户系统:users表区分销售员与经理角色,控制访问权限。数据库设计通过外键约束保障数据一致性,例如客户归属用户、跟进记录绑定客户与操作人。为提升性能,建议在常用查询字段建立索引,如customers(owner_id)和interactions(customer_id);同时可添加is_deleted字段实现软删除。典型查询涵盖查看某销售员客户及其最新跟进情况、统计各阶段商机总额以及识别超过30天未联系的客户。开发上推荐使用bcrypt加密密码,结合后端语言提供api接口,前端采用bootstrap+jquery快速构建界面。后续可扩展合同管理、任务提醒等功能以适应业务增长。

如何在mysql中设计简单crm系统_mysql crm系统项目实战

明确CRM系统核心功能模块

一个简单的CRM系统主要围绕客户信息管理、跟进记录、销售机会和基础用户权限展开。设计前先理清需要支持的核心功能:

  • 客户管理:保存客户基本信息(姓名、公司、联系方式等)
  • 联系记录:记录与客户的沟通内容、时间、负责人
  • 销售阶段跟踪:管理潜在客户转化过程(如初步接触、报价、成交)
  • 用户账户系统:区分不同销售人员或角色

这些功能决定了数据库表结构的基本方向。

设计MySQL数据表结构

基于功能需求,创建以下几张核心表:

1. 用户表(users)
CREATE TABLE users (
  id INT AUTO_INCREMENT PRIMARY KEY,
  username VARCHAR(50) NOT NULL UNIQUE,
  password VARCHAR(255) NOT NULL,
  name VARCHAR(100),
  role ENUM('sales', 'manager') DEFAULT 'sales',
  created_at DATETIME DEFAULT CURRENT_TIMESTAMP
);
2. 客户表(customers)
CREATE TABLE customers (
  id INT AUTO_INCREMENT PRIMARY KEY,
  name VARCHAR(100) NOT NULL,
  company VARCHAR(100),
  phone VARCHAR(20),
  email VARCHAR(100),
  owner_id INT,
  status ENUM('new', 'contacted', 'qualified', 'lost', 'converted') DEFAULT 'new',
  created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
  FOREIGN KEY (owner_id) REFERENCES users(id)
);
3. 跟进记录表(interactions)
CREATE TABLE interactions (
  id INT AUTO_INCREMENT PRIMARY KEY,
  customer_id INT NOT NULL,
  user_id INT NOT NULL,
  contact_date DATE NOT NULL,
  type ENUM('call', 'email', 'meeting') DEFAULT 'call',
  notes TEXT,
  created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
  FOREIGN KEY (customer_id) REFERENCES customers(id) ON DELETE CASCADE,
  FOREIGN KEY (user_id) REFERENCES users(id)
);
4. 销售机会表(opportunities)
CREATE TABLE opportunities (
  id INT AUTO_INCREMENT PRIMARY KEY,
  customer_id INT NOT NULL,
  title VARCHAR(200) NOT NULL,
  amount DECIMAL(10,2),
  stage ENUM('prospecting', 'proposal', 'negotiation', 'won', 'lost') DEFAULT 'prospecting',
  expected_close_date DATE,
  created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
  updated_at DATETIME ON UPDATE CURRENT_TIMESTAMP,
  FOREIGN KEY (customer_id) REFERENCES customers(id) ON DELETE CASCADE
);

表之间通过外键关联,确保数据一致性。比如客户归属某个销售员,每条跟进记录对应具体客户和操作人。

What-the-Diff
What-the-Diff

检查请求差异,自动生成更改描述

下载

常用查询语句示例

系统运行后,常需统计分析。以下是几个实用的SQL查询:

查看某销售员名下客户及最近跟进
SELECT 
  c.name AS customer_name,
  c.company,
  c.status,
  i.contact_date,
  i.notes
FROM customers c
LEFT JOIN interactions i ON c.id = i.customer_id 
  AND i.id IN (
    SELECT MAX(id) FROM interactions GROUP BY customer_id
  )
WHERE c.owner_id = 1;
统计各阶段销售机会金额
SELECT 
  stage,
  COUNT(*) AS deal_count,
  SUM(amount) AS total_amount
FROM opportunities 
WHERE stage != 'won' AND stage != 'lost'
GROUP BY stage;
查找长时间未跟进的客户
SELECT 
  c.name,
  c.phone,
  MAX(i.contact_date) AS last_contact
FROM customers c
LEFT JOIN interactions i ON c.id = i.customer_id
GROUP BY c.id
HAVING last_contact < DATE_SUB(CURDATE(), INTERVAL 30 DAY) OR last_contact IS NULL;

开发建议与扩展思路

实际使用中可以逐步增强功能:

  • 加入索引优化查询性能,例如在customers(owner_id)interactions(customer_id)上建索引
  • 添加数据软删除机制(增加is_deleted字段)
  • 通过视图简化复杂查询
  • 配合PHP/Python/Node.js等后端语言实现增删改查接口
  • 前端可用Bootstrap + jQuery快速搭建界面

安全方面注意对用户密码使用bcrypt或SHA2加密,避免明文存储。

基本上就这些。从建表到查询,这套结构足以支撑一个轻量级CRM系统运行。后续可根据业务增长加入合同、任务提醒、数据导入等功能。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1133

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

381

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

2152

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

380

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1663

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

440

2024.04.29

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 846人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号