Files
hzhub/hzhub-ai/hzhub-modules/hzhub-chat/docs/数据库智能体实现总结.md
大壮 c2513849b4 feat: 添加ERP服务和系统服务,完善员工门户功能
## 新增服务模块

### 1. ERP服务 (hzhub-erp)
- 新增独立的ERP数据适配服务
- 支持SQL Server 2008 R2数据源
- 提供动态API配置管理系统
- 包含客户管理、销售数据等业务接口

### 2. 系统服务 (hzhub-system)
- 新增独立的系统管理服务
- 用户、角色、权限、部门、菜单管理
- 租户管理、操作日志、在线用户监控
- 工作流引擎(warm-flow)集成
- 企业微信审批同步功能

### 3. API网关 (hzhub-gateway)
- 新增Spring Cloud Gateway网关服务
- JWT认证、路由分发、限流熔断
- XSS防护、请求日志记录
- 统一入口端口8080

## 后台管理功能增强

### ERP动态API管理
- 新增动态API配置管理界面
- API测试、文档预览、统计监控
- 错误日志查看、缓存管理
- 从数据库表自动导入API配置

### 系统管理增强
- 企业微信配置管理
- 企业微信审批同步配置
- 部门和用户管理优化

## 员工门户功能完善

### 业务页面
- 审批中心:工作流审批、待办任务
- CRM管理:客户关系管理
- 经销商管理:经销商数据展示
- 供应链管理:采购、库存、销售
- BI报表:数据可视化分析
- ERP数据探索:SQL Server数据查询

### 个人中心
- 基本设置:个人信息管理
- 安全设置:密码修改、登录日志
- 锁屏功能:自动锁屏、手动锁屏

### 其他功能
- 标签页管理:多标签页导航
- 页面缓存:keepAlive缓存机制
- 会话超时:自动检测并提示

## 经销商门户

### 页面路由
- 新增经销商管理页面路由
- AI聊天界面完善

## 文档更新

- ERP API数据库初始化指南
- ERP API前端完整实现文档
- ERP API测试和验证指南
- Gateway路由迁移计划
- 项目配置文档更新

## 部署脚本

- 统一启动/停止/重启脚本
- Docker Compose配置优化
- Nginx配置文件更新

## 技术栈

- 后端: Spring Boot 3.5.8, Java 17
- 前端: Vue 3, TypeScript, Element Plus, Vben Admin
- 工作流: warm-flow 1.8.2
- 网关: Spring Cloud Gateway
- 数据库: MySQL 8.0, SQL Server 2008 R2
- 缓存: Redis 7
- 向量库: Weaviate 1.25.0

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-05-08 08:00:19 +00:00

4.5 KiB
Executable File
Raw Permalink Blame History

数据库操作智能体实现总结

概述

基于 LangChain4j 的 Pure agentic AI 模式,完成了一个智能数据库查询系统。该系统能够根据用户的自然语言问题,自动分析数据库结构、生成查询计划并执行相应的数据库操作。

架构设计

1. 整体框架

用户请求 → SupervisorAgent(协调器) → SqlAgent(数据库专家) → 数据库工具 → 数据库
                                                            ↓
                                                      结果处理与响应

2. 核心组件

A. SqlAgent (数据库查询专家)

  • 文件: org.hzhub.agent.SqlAgent
  • 职责: 根据用户的自然语言问题,调用相应的工具查询数据库
  • 使用的工具:
    • QueryAllTablesTool: 查询所有表名和注释
    • QueryTableSchemaTool: 查询表的DDLCREATE TABLE语句
    • ExecuteSqlQueryTool: 执行SELECT查询
public interface SqlAgent {
    @SystemMessage("...")  // 详细的系统提示
    @UserMessage("请回答以下问题:{{query}}")
    @Agent("一个智能数据库查询助手...")
    String getData(@V("query") String query);
}

B. SupervisorAgent (总体协调器)

  • OpenAIServiceImpl.doAgent() 中创建
  • 作用:协调 SqlAgent 的执行,管理任务流程
  • 响应策略:SUMMARY - 返回所有操作的摘要
SupervisorAgent supervisor = AgenticServices
    .supervisorBuilder()
    .chatModel(PLANNER_MODEL)
    .subAgents(sqlAgent)
    .responseStrategy(SupervisorResponseStrategy.SUMMARY)
    .build();

C. 数据库工具 (Tools)

1. QueryAllTablesTool
@Tool("Query all tables in the database and return table names and basic information")
public String queryAllTables()
  • 返回数据库中所有表的名称和注释
  • 使用注入的 agentDataSource DataSource
2. QueryTableSchemaTool
@Tool("Query the CREATE TABLE statement (DDL) for a specific table by table name")
public String queryTableSchema(String tableName)
  • 返回指定表的建表SQL语句
  • 包含SQL注入防护表名有效性验证
3. ExecuteSqlQueryTool
@Tool("Execute a SELECT SQL query and return the results. Example: SELECT * FROM sys_user")
public String executeSql(String sql)
  • 执行SELECT查询安全性考虑不允许执行其他操作
  • 格式化查询结果最多显示前20行

3. 配置体系

AgentMysqlProperties

配置文件前缀:agent.mysql

agent:
  mysql:
    enabled: true
    url: jdbc:mysql://localhost:3306/your_database
    username: your_username
    password: your_password
    max-pool-size: 10
    min-idle: 2

AgentMysqlConfig

  • 创建独立的 DataSource Bean (agentDataSource)
  • 使用 HikariCP 连接池管理
  • 与项目主数据源隔离

TableSchemaManager

  • 在应用启动时初始化表结构缓存
  • 使用 ConcurrentHashMap 存储结构信息
  • 支持按需刷新单个表的结构

工作流程示例

用户查询: "数据库有哪些表?"

1. SupervisorAgent 接收请求
   ↓
2. SupervisorAgent 分析请求,决定调用 SqlAgent
   ↓
3. SqlAgent 理解需求,调用 QueryAllTablesTool
   ↓
4. QueryAllTablesTool 连接数据库,获取所有表
   ↓
5. 结果返回给 SqlAgent
   ↓
6. SqlAgent 格式化结果
   ↓
7. SupervisorAgent 生成最终摘要
   ↓
8. 结果通过流式处理器返回给用户

用户查询: "查询 sys_user 表中有多少条记录"

1. SqlAgent 接收请求
   ↓
2. SqlAgent 分析需求,可能先调用 QueryTableSchemaTool 了解表结构
   ↓
3. 然后调用 ExecuteSqlQueryTool 执行 "SELECT COUNT(*) FROM sys_user"
   ↓
4. 获取查询结果并返回

Agentic AI 特性

自适应决策

  • Agent 能根据上下文和之前的结果决定下一步操作
  • 不是预定义的固定流程,而是动态适应

例子

当询问"查询部门表的字段信息时"

  • SqlAgent 可能先调用 QueryTableSchemaTool 获取建表SQL
  • 如果发现需要具体的数据示例,会继续调用 ExecuteSqlQueryTool
  • 整个决策过程由 LLM 驱动,非硬编码

安全考虑

  1. 数据源隔离: Agent 使用独立的数据源agentDataSource与主应用隔离
  2. SQL验证: 只允许执行 SELECT 查询
  3. 表名验证: 表名必须通过正则表达式验证防止SQL注入
  4. 权限限制: 可通过 AGENT_ALLOWED_TABLES 环境变量限制可访问的表
  5. 凭证管理: 数据库凭证通过配置文件管理,不硬编码