Claude Code Lab-3(下):三能力 MCP Server

describe_schema + read_wiki + append_report_section,draft 人审后合并。

  1. schema 查询 --- 样例库表结构
  2. Wiki 读 --- 业务枚举与流程说明
  3. 报告片段 --- 按模板追加章节(仍人审后合并)

能力一:describe_schema

python 复制代码
@server.tool()
def describe_schema(table: str | None = None) -> str:
    """Return CREATE TABLE or list of tables for demo DB."""

用途: 写报告「数据模型」章时,不必 @ 整个 schema/,tool 返回当前结构。

Prompt:

text 复制代码
用 MCP tool describe_schema 列出 orders 相关表,把结果写入 docs/research-report.md §数据模型。
只读,不要执行 DML。

能力二:read_wiki

python 复制代码
@server.tool()
def read_wiki(page: str) -> str:
    """Read markdown from resources/wiki/{page}.md"""

用途: 对齐业务语义(status 枚举、退款规则)。

与 Resource URI 的关系: 可以 tool 包一层 resource,培训统一用 tool 方便 Claude 发现。


能力三:append_report_section

python 复制代码
@server.tool()
def append_report_section(section: str, markdown: str) -> str:
    """Append to docs/research-report.draft.md only, not final report."""

设计选择: 不直接写 research-report.md,写 draft 文件,人 diff 后合并------避免 Agent 一次写坏定稿。

模板约束: @prompts/report-section-template.md 规定每节标题与必填字段(path 引用、待确认)。


端到端工作流

text 复制代码
1. 人:@notes/lab3-scope.md 开 Agent
2. Agent:入口追踪(读码)→ 调 read_wiki 补业务含义
3. Agent:调 describe_schema 写数据模型
4. Agent:调 append_report_section 分节写入 draft
5. 人:review draft → 合并到 research-report.md → 生成 PNG

Command 可选: /lab3-report 预填上述步骤 2--4 的 Constraints。


测试与验收

bash 复制代码
pytest mcp-servers/training-wiki/tests/ -q

验收标准:

  • 三 tool 在 Claude Code MCP 列表可见
  • 恶意 path / 写 SQL 被拒绝
  • draft 合并后报告仍满足第 15 篇人审清单

踩坑

坑 1:append_report_section 直接覆盖整份报告

修正: 仅 append draft;section 名重复则报错。

坑 2:Wiki 与代码不一致,报告两边都信

修正: 报告表格加「来源:code | wiki」,冲突标待确认。

坑 3:MCP 配好但 Claude 不用 tool,仍瞎编

修正: CLAUDE.md 写「查表结构 必须 describe_schema」;培训 demo 先只开 MCP 不 @ schema 文件。


小结

  1. Lab-3 下 = schema + Wiki + draft 报告 三能力 MCP。
  2. 报告写 draft、人合并,MCP 不替代读码验证。
  3. M8 Agent 循环与 Lab-4 Review 接 Hook。

下一篇

第 18 篇《Agent 循环:感知 → 规划 → 行动 → 观察》

第 19 篇《Lab-4:Code Review Agent 到 pre-commit》


相关推荐
java小白小2 小时前
SpringBoot(07):事务管理——@Transactional 你真的用对了吗?
后端
shepherd1113 小时前
吞吐量提升 10 倍:高并发大批量数据处理任务的架构演进与性能调优
java·后端·架构
java小白小3 小时前
SpringBoot(05):Spring Data JPA——用面向对象的方式操作数据库
后端
juejin9983 小时前
Claude Code Lab-2(上):自然语言查库助手
后端
java小白小3 小时前
SpringBoot(06):多数据源配置——一个项目连多个库怎么做
后端
程序员cxuan4 小时前
Codex 会把磁盘给烧了?完整复盘来了!
人工智能·后端·程序员
ClouGence4 小时前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
快乐肚皮5 小时前
深入理解Loop Engineering
前端·后端
小兔崽子去哪了5 小时前
Vue3 + Pinia 集成 IGV.js 实现 BAM 文件在线浏览
javascript·vue.js·后端