当前位置: 首页 > news >正文

ruoyi-vue-pro 使用记录(4)

ruoyi-vue-pro 使用记录(4)

  • CRM
    • 数据库
      • 线索
      • 客户
      • 商机
      • 合同
      • 回款
      • 产品
      • 其他

CRM

文档
主要分为 6 个核心模块:线索、客户、商机、合同、回款、产品。

  • 线索管理以 crm_clue 作为核心表
  • 客户管理以 crm_customer 作为核心表
  • 商机管理以 crm_business 作为核心表
  • 合同管理以 crm_contract 作为核心表
  • 回款管理以 crm_receivable 作为核心表
  • 产品管理以 crm_product 作为核心表

数据库

线索

DROP TABLE IF EXISTS `crm_clue`;
CREATE TABLE `crm_clue` (`id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '编号,主键自增',`name` VARCHAR(255) NOT NULL COMMENT '线索名称',`follow_up_status` TINYINT(1) NOT NULL COMMENT '跟进状态',`contact_last_time` DATETIME NOT NULL COMMENT '最后跟进时间',`contact_last_content` TEXT NOT NULL COMMENT '最后跟进内容',`contact_next_time` DATETIME NOT NULL COMMENT '下次联系时间',`owner_user_id` BIGINT(20) NOT NULL COMMENT '负责人的用户编号',`transform_status` TINYINT(1) NOT NULL COMMENT '转化状态',`customer_id` BIGINT(20) NOT NULL COMMENT '客户编号',`mobile` VARCHAR(20) NOT NULL COMMENT '手机号',`telephone` VARCHAR(20) NOT NULL COMMENT '电话',`qq` VARCHAR(20) NOT NULL COMMENT 'QQ',`wechat` VARCHAR(50) NOT NULL COMMENT 'wechat',`email` VARCHAR(255) NOT NULL COMMENT 'email',`area_id` INT(11) NOT NULL COMMENT '所在地,关联 Area 的 id 字段',`detail_address` VARCHAR(255) NOT NULL COMMENT '详细地址',`industry_id` INT(11) NOT NULL COMMENT '所属行业,对应字典 CRM_CUSTOMER_INDUSTRY',`level` INT(11) NOT NULL COMMENT '客户等级,对应字典 CRM_CUSTOMER_LEVEL',`source` INT(11) NOT NULL COMMENT '客户来源,对应字典 CRM_CUSTOMER_SOURCE',`remark` VARCHAR(255) NOT NULL COMMENT '备注',`creator` varchar(64) DEFAULT '' COMMENT '创建者',`create_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT '创建时间',`updater` varchar(64)  COMMENT '更新者',`update_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT '更新时间',`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',`tenant_id` bigint(20) NOT NULL DEFAULT 0 COMMENT '租户编号',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='CRM线索表';

客户

DROP TABLE IF EXISTS `crm_customer`;
CREATE TABLE `crm_customer` (`id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '编号',`name` VARCHAR(255) NOT NULL COMMENT '客户名称',`follow_up_status` TINYINT(1) NOT NULL COMMENT '跟进状态',`contact_last_time` DATETIME NOT NULL COMMENT '最后跟进时间',`contact_last_content` TEXT NOT NULL COMMENT '最后跟进内容',`contact_next_time` DATETIME NOT NULL COMMENT '下次联系时间',`owner_user_id` BIGINT(20) NOT NULL COMMENT '负责人的用户编号,关联 AdminUserDO 的 id 字段',`owner_time` DATETIME NOT NULL COMMENT '成为负责人的时间',`lock_status` TINYINT(1) NOT NULL COMMENT '锁定状态',`deal_status` TINYINT(1) NOT NULL COMMENT '成交状态',`mobile` VARCHAR(20) NOT NULL COMMENT '手机',`telephone` VARCHAR(20) NOT NULL COMMENT '电话',`qq` VARCHAR(20) NOT NULL COMMENT 'QQ',`wechat` VARCHAR(50) NOT NULL COMMENT 'wechat',`email` VARCHAR(255) NOT NULL COMMENT 'email',`area_id` INT(11) NOT NULL COMMENT '所在地,关联 Area 的 id 字段',`detail_address` VARCHAR(255) NOT NULL COMMENT '详细地址',`industry_id` INT(11) NOT NULL COMMENT '所属行业,对应字典 CRM_CUSTOMER_INDUSTRY',`level` INT(11) NOT NULL COMMENT '客户等级,对应字典 CRM_CUSTOMER_LEVEL',`source` INT(11) NOT NULL COMMENT '客户来源,对应字典 CRM_CUSTOMER_SOURCE',`remark` VARCHAR(255) NOT NULL COMMENT '备注',`creator` varchar(64) DEFAULT '' COMMENT '创建者',`create_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT '创建时间',`updater` varchar(64)  COMMENT '更新者',`update_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT '更新时间',`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',`tenant_id` bigint(20) NOT NULL DEFAULT 0 COMMENT '租户编号',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='CRM客户表';DROP TABLE IF EXISTS `crm_customer_limit_config`;
CREATE TABLE `crm_customer_limit_config` (`id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '编号',`type` INT(11) NOT NULL COMMENT '规则类型',`user_ids` TEXT COMMENT '规则适用人群',`dept_ids` TEXT COMMENT '规则适用部门',`max_count` INT(11) NOT NULL COMMENT '数量上限',`deal_count_enabled` TINYINT(1) NOT NULL COMMENT '成交客户是否占有拥有客户数,当且仅当 type 为 1 时使用',`creator` varchar(64) DEFAULT '' COMMENT '创建者',`create_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT '创建时间',`updater` varchar(64)  COMMENT '更新者',`update_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT '更新时间',`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',`tenant_id` bigint(20) NOT NULL DEFAULT 0 COMMENT '租户编号',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='CRM客户限制配置表';DROP TABLE IF EXISTS `crm_customer_pool_config`;
CREATE TABLE `crm_customer_pool_config` (`id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '编号',`enabled` TINYINT(1) NOT NULL COMMENT '是否启用客户公海',`contact_expire_days` INT(11) NOT NULL COMMENT '未跟进放入公海天数',`deal_expire_days` INT(11) NOT NULL COMMENT '未成交放入公海天数',`notify_enabled` TINYINT(1) NOT NULL COMMENT '是否开启提前提醒',`notify_days` INT(11) NOT NULL COMMENT '提前提醒天数',`creator` varchar(64) DEFAULT '' COMMENT '创建者',`create_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT '创建时间',`updater` varchar(64)  COMMENT '更新者',`update_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT '更新时间',`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',`tenant_id` bigint(20) NOT NULL DEFAULT 0 COMMENT '租户编号',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='CRM客户公海配置表';

商机

DROP TABLE IF EXISTS `crm_business`;
CREATE TABLE `crm_business` (`id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '编号',`name` VARCHAR(255) NOT NULL COMMENT '商机名称',`customer_id` BIGINT(20) NOT NULL COMMENT '客户编号',`follow_up_status` TINYINT(1) NOT NULL COMMENT '跟进状态',`contact_last_time` DATETIME NOT NULL COMMENT '最后跟进时间',`contact_next_time` DATETIME NOT NULL COMMENT '下次联系时间',`owner_user_id` BIGINT(20) NOT NULL COMMENT '负责人的用户编号',`status_type_id` BIGINT(20) NOT NULL COMMENT '商机状态组编号',`status_id` BIGINT(20) NOT NULL COMMENT '商机状态编号',`end_status` INT(11) NOT NULL COMMENT '结束状态',`end_remark` VARCHAR(255) NOT NULL COMMENT '结束时的备注',`deal_time` DATETIME NOT NULL COMMENT '预计成交日期',`total_product_price` DECIMAL(10,2) NOT NULL COMMENT '产品总金额,单位:元',`discount_percent` DECIMAL(10,2) NOT NULL COMMENT '整单折扣,百分比',`total_price` DECIMAL(10,2) NOT NULL COMMENT '商机总金额,单位:元',`remark` VARCHAR(255) NOT NULL COMMENT '备注',`creator` varchar(64) DEFAULT '' COMMENT '创建者',`create_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT '创建时间',`updater` varchar(64)  COMMENT '更新者',`update_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT '更新时间',`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',`tenant_id` bigint(20) NOT NULL DEFAULT 0 COMMENT '租户编号',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='CRM商机表';DROP TABLE IF EXISTS `crm_business_product`;
CREATE TABLE `crm_business_product` (`id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '主键',`business_id` BIGINT(20) NOT NULL COMMENT '商机编号',`product_id` BIGINT(20) NOT NULL COMMENT '产品编号',`product_price` DECIMAL(10,2) NOT NULL COMMENT '产品单价,单位:元',`business_price` DECIMAL(10,2) NOT NULL COMMENT '商机价格,单位:元',`count` DECIMAL(10,2) NOT NULL COMMENT '数量',`total_price` DECIMAL(10,2) NOT NULL COMMENT '总计价格,单位:元,totalPrice = business_price * count',`creator` varchar(64) DEFAULT '' COMMENT '创建者',`create_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT '创建时间',`updater` varchar(64)  COMMENT '更新者',`update_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT '更新时间',`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',`tenant_id` bigint(20) NOT NULL DEFAULT 0 COMMENT '租户编号',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='CRM商机产品表';DROP TABLE IF EXISTS `crm_business_status`;
CREATE TABLE `crm_business_status` (`id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '主键',`type_id` BIGINT(20) NOT NULL COMMENT '状态类型编号',`name` VARCHAR(255) NOT NULL COMMENT '状态名',`percent` INT(11) NOT NULL COMMENT '赢单率,百分比',`sort` INT(11) NOT NULL COMMENT '排序',`creator` varchar(64) DEFAULT '' COMMENT '创建者',`create_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT '创建时间',`updater` varchar(64)  COMMENT '更新者',`update_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT '更新时间',`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',`tenant_id` bigint(20) NOT NULL DEFAULT 0 COMMENT '租户编号',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='CRM商机状态表';DROP TABLE IF EXISTS `crm_business_status_type`;
CREATE TABLE `crm_business_status_type` (`id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '主键',`name` VARCHAR(255) NOT NULL COMMENT '状态类型名',`dept_ids` TEXT COMMENT '使用的部门编号',`creator` varchar(64) DEFAULT '' COMMENT '创建者',`create_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT '创建时间',`updater` varchar(64)  COMMENT '更新者',`update_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT '更新时间',`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',`tenant_id` bigint(20) NOT NULL DEFAULT 0 COMMENT '租户编号',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='CRM商机状态类型表';

合同

DROP TABLE IF EXISTS `crm_contract`;
CREATE TABLE `crm_contract` (`id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '合同编号',`name` VARCHAR(255) NOT NULL COMMENT '合同名称',`no` VARCHAR(255) NOT NULL COMMENT '合同编号',`customer_id` BIGINT(20) NOT NULL COMMENT '客户编号',`business_id` BIGINT(20) COMMENT '商机编号段',`contact_last_time` DATETIME NOT NULL COMMENT '最后跟进时间',`owner_user_id` BIGINT(20) NOT NULL COMMENT '负责人的用户编号',`process_instance_id` VARCHAR(255) COMMENT '工作流编号',`audit_status` INT(11) NOT NULL COMMENT '审批状态',`order_date` DATETIME NOT NULL COMMENT '下单日期',`start_time` DATETIME NOT NULL COMMENT '开始时间',`end_time` DATETIME NOT NULL COMMENT '结束时间',`total_product_price` DECIMAL(19, 2) NOT NULL COMMENT '产品总金额,单位:元',`discount_percent` DECIMAL(19, 2) NOT NULL COMMENT '整单折扣',`total_price` DECIMAL(19, 2) NOT NULL COMMENT '合同总金额,单位:分',`sign_contact_id` BIGINT(20) COMMENT '客户签约人',`sign_user_id` BIGINT(20) COMMENT '公司签约人',`remark` TEXT COMMENT '备注',`creator` varchar(64) DEFAULT '' COMMENT '创建者',`create_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT '创建时间',`updater` varchar(64)  COMMENT '更新者',`update_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT '更新时间',`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',`tenant_id` bigint(20) NOT NULL DEFAULT 0 COMMENT '租户编号',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='CRM合同表';DROP TABLE IF EXISTS `crm_contract_config`;
CREATE TABLE `crm_contract_config` (`id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '编号',`notify_enabled` TINYINT(1) NOT NULL COMMENT '是否开启提前提醒',`notify_days` INT(11) NOT NULL COMMENT '提前提醒天数',`creator` varchar(64) DEFAULT '' COMMENT '创建者',`create_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT '创建时间',`updater` varchar(64)  COMMENT '更新者',`update_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT '更新时间',`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',`tenant_id` bigint(20) NOT NULL DEFAULT 0 COMMENT '租户编号',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='CRM合同配置表';DROP TABLE IF EXISTS `crm_contract_product`;
CREATE TABLE `crm_contract_product` (`id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '主键',`contract_id` BIGINT(20) NOT NULL COMMENT '合同编号',`product_id` BIGINT(20) NOT NULL COMMENT '产品编号',`product_price` DECIMAL(19, 2) NOT NULL COMMENT '产品单价,单位:元',`contract_price` DECIMAL(19, 2) NOT NULL COMMENT '合同价格,单位:元',`count` DECIMAL(19, 2) NOT NULL COMMENT '数量',`total_price` DECIMAL(19, 2) NOT NULL COMMENT '总计价格,单位:元',`creator` varchar(64) DEFAULT '' COMMENT '创建者',`create_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT '创建时间',`updater` varchar(64)  COMMENT '更新者',`update_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT '更新时间',`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',`tenant_id` bigint(20) NOT NULL DEFAULT 0 COMMENT '租户编号',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='CRM合同产品表';

回款

DROP TABLE IF EXISTS `crm_receivable`;
CREATE TABLE `crm_receivable` (`id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT 'ID',`no` VARCHAR(255) NOT NULL COMMENT '回款编号',`plan_id` BIGINT(20) COMMENT '回款计划编号',`customer_id` BIGINT(20) NOT NULL COMMENT '客户编号',`contract_id` BIGINT(20) NOT NULL COMMENT '合同编号',`owner_user_id` BIGINT(20) NOT NULL COMMENT '负责人编号',`return_time` DATETIME NOT NULL COMMENT '回款日期',`return_type` INT(11) NOT NULL COMMENT '回款方式',`price` DECIMAL(19, 2) NOT NULL COMMENT '计划回款金额,单位:元',`remark` VARCHAR(255) NOT NULL COMMENT '备注',`process_instance_id` VARCHAR(255) COMMENT '工作流编号',`audit_status` INT(11) NOT NULL COMMENT '审批状态',`creator` varchar(64) DEFAULT '' COMMENT '创建者',`create_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT '创建时间',`updater` varchar(64)  COMMENT '更新者',`update_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT '更新时间',`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',`tenant_id` bigint(20) NOT NULL DEFAULT 0 COMMENT '租户编号',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='CRM回款表';DROP TABLE IF EXISTS `crm_receivable_plan`;
CREATE TABLE `crm_receivable_plan` (`id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '编号',`period` INT(11) NOT NULL COMMENT '期数',`customer_id` BIGINT(20) NOT NULL COMMENT '客户编号',`contract_id` BIGINT(20) NOT NULL COMMENT '合同编号',`owner_user_id` BIGINT(20) NOT NULL COMMENT '负责人编号',`return_time` DATETIME NOT NULL COMMENT '计划回款日期',`return_type` INT(11) NOT NULL COMMENT '计划回款类型',`price` DECIMAL(19, 2) NOT NULL COMMENT '计划回款金额,单位:元',`receivable_id` BIGINT(20) COMMENT '回款编号',`remind_days` INT(11) NOT NULL COMMENT '提前几天提醒',`remind_time` DATETIME NOT NULL COMMENT '提醒日期',`remark` VARCHAR(255) NOT NULL COMMENT '备注',`creator` varchar(64) DEFAULT '' COMMENT '创建者',`create_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT '创建时间',`updater` varchar(64)  COMMENT '更新者',`update_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT '更新时间',`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',`tenant_id` bigint(20) NOT NULL DEFAULT 0 COMMENT '租户编号',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='CRM回款计划表';

产品

DROP TABLE IF EXISTS `crm_product`;
CREATE TABLE `crm_product` (`id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '编号',`name` VARCHAR(255) NOT NULL COMMENT '产品名称',`no` VARCHAR(255) NOT NULL COMMENT '产品编码',`unit` INT(11) NOT NULL COMMENT '单位,字典 CRM_PRODUCT_UNIT',`price` DECIMAL(19, 2) NOT NULL COMMENT '价格,单位:元',`status` INT(11) NOT NULL COMMENT '状态',`category_id` BIGINT(20) NOT NULL COMMENT '产品分类 ID',`description` VARCHAR(255) NOT NULL COMMENT '产品描述',`owner_user_id` BIGINT(20) NOT NULL COMMENT '负责人的用户编号',`creator` varchar(64) DEFAULT '' COMMENT '创建者',`create_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT '创建时间',`updater` varchar(64)  COMMENT '更新者',`update_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT '更新时间',`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',`tenant_id` bigint(20) NOT NULL DEFAULT 0 COMMENT '租户编号',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='CRM产品表';DROP TABLE IF EXISTS `crm_product_category`;
CREATE TABLE `crm_product_category` (`id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '分类编号',`name` VARCHAR(255) NOT NULL COMMENT '分类名称',`parent_id` BIGINT(20) NOT NULL COMMENT '父级编号',`creator` varchar(64) DEFAULT '' COMMENT '创建者',`create_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT '创建时间',`updater` varchar(64)  COMMENT '更新者',`update_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT '更新时间',`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',`tenant_id` bigint(20) NOT NULL DEFAULT 0 COMMENT '租户编号',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='CRM产品分类表';

其他

DROP TABLE IF EXISTS `crm_permission`;
CREATE TABLE `crm_permission` (`id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '编号,主键自增',`biz_type` INT(11) NOT NULL COMMENT '数据类型',`biz_id` BIGINT(20) NOT NULL COMMENT '数据编号',`user_id` BIGINT(20) NOT NULL COMMENT '用户编号',`level` INT(11) NOT NULL COMMENT '权限级别',`creator` varchar(64) DEFAULT '' COMMENT '创建者',`create_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT '创建时间',`updater` varchar(64)  COMMENT '更新者',`update_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT '更新时间',`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',`tenant_id` bigint(20) NOT NULL DEFAULT 0 COMMENT '租户编号',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='CRM权限表';DROP TABLE IF EXISTS `crm_follow_up_record`;
CREATE TABLE `crm_follow_up_record` (`id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '编号',`biz_type` INT(11) NOT NULL COMMENT '数据类型',`biz_id` BIGINT(20) NOT NULL COMMENT '数据编号',`type` INT(11) NOT NULL COMMENT '跟进类型',`content` TEXT NOT NULL COMMENT '跟进内容',`next_time` DATETIME NOT NULL COMMENT '下次联系时间',`pic_urls` TEXT COMMENT '图片',`file_urls` TEXT COMMENT '附件',`business_ids` TEXT COMMENT '关联的商机编号数组',`contact_ids` TEXT COMMENT '关联的联系人编号数组',`creator` varchar(64) DEFAULT '' COMMENT '创建者',`create_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT '创建时间',`updater` varchar(64)  COMMENT '更新者',`update_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT '更新时间',`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',`tenant_id` bigint(20) NOT NULL DEFAULT 0 COMMENT '租户编号',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='CRM跟进记录表';DROP TABLE IF EXISTS `crm_contact`;
CREATE TABLE `crm_contact` (`id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '主键',`name` VARCHAR(255) NOT NULL COMMENT '联系人姓名',`customer_id` BIGINT(20) NOT NULL COMMENT '客户编号',`contact_last_time` DATETIME NOT NULL COMMENT '最后跟进时间',`contact_last_content` VARCHAR(255) NOT NULL COMMENT '最后跟进内容',`contact_next_time` DATETIME NOT NULL COMMENT '下次联系时间',`owner_user_id` BIGINT(20) NOT NULL COMMENT '负责人用户编号',`mobile` VARCHAR(20) NOT NULL COMMENT '手机号',`telephone` VARCHAR(20) NOT NULL COMMENT '电话',`email` VARCHAR(255) NOT NULL COMMENT '电子邮箱',`qq` BIGINT(20) NOT NULL COMMENT 'QQ',`wechat` VARCHAR(255) NOT NULL COMMENT '微信',`area_id` INT(11) NOT NULL COMMENT '所在地',`detail_address` VARCHAR(255) NOT NULL COMMENT '详细地址',`sex` INT(11) NOT NULL COMMENT '性别',`master` TINYINT(1) NOT NULL COMMENT '是否关键决策人',`post` VARCHAR(255) NOT NULL COMMENT '职位',`parent_id` BIGINT(20) NOT NULL COMMENT '直属上级',`remark` VARCHAR(255) NOT NULL COMMENT '备注',`creator` varchar(64) DEFAULT '' COMMENT '创建者',`create_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT '创建时间',`updater` varchar(64)  COMMENT '更新者',`update_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT '更新时间',`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',`tenant_id` bigint(20) NOT NULL DEFAULT 0 COMMENT '租户编号',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='CRM联系人表';DROP TABLE IF EXISTS `crm_contact_business`;
CREATE TABLE `crm_contact_business` (`id` BIGINT(20) NOT NULL AUTO_INCREMENT COMMENT '主键',`contact_id` BIGINT(20) NOT NULL COMMENT '联系人编号',`business_id` BIGINT(20) NOT NULL COMMENT '商机编号',`creator` varchar(64) DEFAULT '' COMMENT '创建者',`create_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) COMMENT '创建时间',`updater` varchar(64)  COMMENT '更新者',`update_time` datetime(0) NOT NULL DEFAULT CURRENT_TIMESTAMP(0) ON UPDATE CURRENT_TIMESTAMP(0) COMMENT '更新时间',`deleted` bit(1) NOT NULL DEFAULT b'0' COMMENT '是否删除',`tenant_id` bigint(20) NOT NULL DEFAULT 0 COMMENT '租户编号',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='CRM联系人商机关联表';

相关文章:

ruoyi-vue-pro 使用记录(4)

ruoyi-vue-pro 使用记录(4) CRM数据库线索客户商机合同回款产品其他 CRM 文档 主要分为 6 个核心模块:线索、客户、商机、合同、回款、产品。 线索管理以 crm_clue 作为核心表客户管理以 crm_customer 作为核心表商机管理以 crm_business 作…...

【17-Ⅱ】Head First Java 学习笔记

HeadFirst Java 本人有C语言基础,通过阅读Java廖雪峰网站,简单速成了java,但对其中一些入门概念有所疏漏,阅读本书以弥补。 第一章 Java入门 第二章 面向对象 第三章 变量 第四章 方法操作实例变量 第五章 程序实战 第六章 Java…...

订单超时自动取消的实践方案

1、定时任务方案 方案流程: 每隔 30 秒查询数据库,取出最近的 N 条未支付的订单。 遍历查询出来的订单列表,判断当前时间减去订单的创建时间是否超过了支付超时时间,如果超时则对该订单执行取消操作。 定时任务方案工程实现相…...

【gin框架入门】

1.介绍 Gin 是一个用 Golang编写的 高性能的web 框架, 由于http路由的优化,速度提高了近 40 倍。 Gin的特点就是封装优雅、API友好。 Gin的一些特性: 快速 基于 Radix 树的路由,小内存占用。没有反射。可预测的 API 性能。 支持中间件 传入…...

dev c++调试录入数字后回车直接关闭

1、我的dev c版本是5.11 2、输入7后,回车就没有了,原因是1013,1.cpp未包含在项目中 3、新建项目,并将test_debug.cpp包含在项目内,就可以下断点调试了...

java期末复习

java jdk jre jvm .java-------->.class----jvm---->机器语言 编写源文件 编译源文件生成字节码 加载运行字节码 java语句执行顺序 顺序 选择 循环 异常处理 基本语法 方法格式 权限修饰符 返回值声明 方法名称(参数列表){方法中封装的逻辑功能;return 返回值;}–权…...

让新手变中手的ChatGPT 使用方法

让新手变中手的ChatGPT 使用方法 已经要一年了,没想到这篇还是一样有用。看到许多依然是一句话就要问出结果的教学,就知道AI 进步很快,但人的学习速度还需要更多时间。 以下为去年原版内容加上新的两招更新,希望帮助你使用ChatGPT 更好用,当未来文字可直接生成影像时,你…...

桥接模式类图与代码

欲开发一个绘图软件,要求使用不同的绘图程序绘制不同的图形。以绘制直线和圆形为例,对应的绘图程序如表 7.7 所示。 根据绘图软件的扩展性要求,该绘图软件将不断扩充新的图形和新的绘图程序。为了避免出现类爆炸的情况,现采用桥接…...

Oracle count的优化-避免全表扫描

Oracle count的优化-避免全表扫描 select count(*) from t1; 这句话比较简单,但很有玄机!对这句话运行的理解,反映了你对数据库的理解深度! 建立实验的大表他t1 SQL> conn scott/tiger 已连接。 SQL> drop table t1 purge…...

leetcode17. 电话号码的字母组合

题目描述: 给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。答案可以按 任意顺序 返回。给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。 示例 1: 输入:digits "…...

如何设计与管理一个前端项目

目录 前端项目设计 前端项目搭建 洞察项目瓶颈 方案调研与选型对比 前端项目管理 合理的分工排期 风险把控 及时反馈与复盘 结束语 如果说基础知识的掌握是起跑线,那么使大家之间拉开差距的更多是前端项目开发经验和技能。对于一个项目来说,从框…...

【MQTT】mosquitto 的 “下载、交叉编译、使用” 详细教程,手把手搭建一个MQTT Broker

😁博客主页😁:🚀https://blog.csdn.net/wkd_007🚀 🤑博客内容🤑:🍭嵌入式开发、Linux、C语言、C、数据结构、音视频🍭 ⏰发布时间⏰:2024-05-11 0…...

用云手机打造海外社媒矩阵

在全球经济一体化的大背景下,中国出海企业及B2B外贸公司正将海外社交媒体营销作为重要的市场拓展策略。为更好地触及不同受众群体,构建跨平台的社媒矩阵已成为企业营销的关键步骤。本文将探讨如何利用云手机技术,高效管理并运营多个海外社交媒…...

第 8 章 机器人平台设计之底盘实现(自学二刷笔记)

重要参考: 课程链接:https://www.bilibili.com/video/BV1Ci4y1L7ZZ 讲义链接:Introduction Autolabor-ROS机器人入门课程《ROS理论与实践》零基础教程 8.4.1 底盘实现_概述 1.ros_arduino_bridge 简介 该功能包包含Arduino库和用来控制Arduino的ROS驱动包&…...

✔ ★Java项目——设计一个消息队列(五)【虚拟主机设计】

虚拟主机设计 创建 VirtualHost实现构造⽅法和 getter创建交换机删除交换机创建队列删除队列创建绑定删除绑定发布消息 ★路由规则1) 实现 route ⽅法2) 实现 checkRoutingKeyValid3) 实现 checkBindingKeyValid4) 实现 routeTopic5) 匹配规则测试⽤例6) 测试 Router 订阅消息1…...

ntfs文件系统的优势 NTFS文件系统的特性有哪些 ntfs和fat32有什么区别 苹果电脑怎么管理硬盘

对于数码科技宅在新购得磁盘之后,出于某种原因会在新的磁盘安装操作系统。在安装操作系统时,首先要对磁盘进行分区和格式化,而在此过程中,操作者们需要选择文件系统。文件系统也决定了之后操作的流程程度,一般文件系统…...

Python Web框架Django项目开发实战:创建在线学习应用

注意:本文的下载教程,与以下文章的思路有相同点,也有不同点,最终目标只是让读者从多维度去熟练掌握本知识点。 下载教程:Python项目开发Django实战-创建在线学习应用-编程案例解析实例详解课程教程.pdf 在当今数字化教…...

用得助全媒体呼叫中心,让AI落到实处帮品牌做营销

怎么让人工智能落到实处的帮助到我们?我们今天来讲讲中关村科金得助全媒体呼叫中心是怎么让AI帮品牌。 这次聊的案例是知名的护肤品牌,该品牌在中国功能性护肤品市场占有率达到20.5%,这么高的市场占有率客户的咨询量也是非常庞大的&#xff0…...

【吃透Java手写】2-Spring(下)-AOP-事务及传播原理

【吃透Java手写】Spring(下)AOP-事务及传播原理 6 AOP模拟实现6.1 AOP工作流程6.2 定义dao接口与实现类6.3 初始化后逻辑6.4 原生Spring的方法6.4.1 实现类6.4.2 定义通知类,定义切入点表达式、配置切面6.4.3 在配置类中进行Spring注解包扫描…...

Spring原理分析--获取Environment资源对象

1.使用getEnvironment()获取环境信息 ApplicationContext接口继承了EnvironmentCapable接口,可以通过getEnvironment()获取Environment配置信息,例如: SpringBootApplication public class A01 {public static void main(String[] args) th…...

Android GPU渲染SurfaceFlinger合成RenderThread的dequeueBuffer/queueBuffer与fence机制(2)

Android GPU渲染SurfaceFlinger合成RenderThread的dequeueBuffer/queueBuffer与fence机制(2) 计算fps帧率 用 adb shell dumpsys SurfaceFlinger --list 查询当前的SurfaceView,然后有好多行,再把要查询的行内容完整的传给 ad…...

人民币数字和中文汉字转换

在PHP中,将人民币的中文汉字金额转换为数字,或者将数字转换为人民币的中文汉字金额,通常需要自定义一些函数来实现这一转换过程。下面分别给出这两个转换的示例代码。 数字转人民币中文汉字 function numberToChinese($num) { $cnNums arr…...

07_Flutter使用NestedScrollView+TabBarView滚动位置共享问题修复

07_Flutter使用NestedScrollViewTabBarView滚动位置共享问题修复 一.案发现场 可以看到,上图中三个列表的滑动位置共享了,滑动其中一个列表,会影响到另外两个,这显然不符合要求,先来看下布局,再说明产生这个…...

Java解决垂直鉴权问题(对垂直权限进行校验)

Java解决垂直鉴权问题(对垂直权限进行校验) 文章目录 Java解决垂直鉴权问题(对垂直权限进行校验)前言一、垂直鉴权是什么?二、实现过程1.新建接口权限菜单映射表2.项目初始化时加载接口菜单映射关系3.自定义过滤器拦截…...

【MySQL工具】pt-heartbeat

功能 pt-heartbeat - 监控 MySQL 复制延迟。 用法 pt-heartbeat [OPTIONS] [DSN] --update|--monitor|--check|--stop pt-heartbeat 用于测量 MySQL 或 PostgreSQL 服务器上的复制延迟。您可以使用它来更新主服务器或监控从服务器。如果可能,MySQL 连接选项将从您…...

实现vant的年月日时分秒组件

方法&#xff1a;van-datetime-picker&#xff08;type&#xff1a;datetime&#xff09;和 van-picker结合实现。 <template><div class"datetimesec-picker"><van-datetime-pickerref"timePickerRef"type"datetime" //年月日时…...

typescript 命名空间、装饰器

1、命名空间 命名空间&#xff1a;在代码量较大的情况下&#xff0c;为了避免各种变量命名的冲突&#xff0c;可将相似功能的函数、类、接口等放置到命名空间内。同Java的包.Net的命名空间一样&#xff0c;typescript 的命名空间可以将代码包裹起来&#xff0c;只对外暴露需要在…...

GPT问答SAP BW

以下回答由GPT-3.5回答,仅供参考. 这个AI工具超好用&#xff0c;每天都有免费额度&#xff0c;写文章、总结长视频、画图等&#xff0c;都几秒搞定&#xff01;快去下载Sider Chrome或Edge插件&#xff0c;薅羊毛&#xff01; https://sider.ai/invited?c43b289bf2616575daecf…...

使用zdppy_amauth开发激活用户接口

服务端代码&#xff1a; 1、创建数据库连接对象2、初始化数据库3、声明一个上下文4、挂载用户相关的路由&#xff0c;这里主要由 用户登录接口用户注册注册获取用户列表接口激活指定用户接口 5、启动服务 import mcrud import api import amauth import env import contextli…...

c++ memset 指针示例

目录 C 传一个float指针&#xff0c;在函数内部修改指针的值 c memset 指针示例 C 传一个float指针&#xff0c;在函数内部修改指针的值 #include <iostream>// 定义一个函数&#xff0c;它接受一个指向float的指针 void modifyValue(float* ptr) {// 通过解引用指针来…...