Spring AI Alibaba - MCP连接 MySQL

先看效果

直接问他数据库有什么表。

大模型调用MySQL进行查询

搭建项目

添加依赖

创建项目后新添加Maven 依赖:

xml 复制代码
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>

<dependency>
    <groupId>org.springframework.ai</groupId>
    <artifactId>spring-ai-mcp-client-spring-boot-starter</artifactId>
    <version>1.0.0-M6</version>
</dependency>

<dependency>
    <groupId>com.alibaba.cloud.ai</groupId>
    <artifactId>spring-ai-alibaba-starter</artifactId>
    <version>1.0.0-M6.1</version>
</dependency>

添加配置

yml 复制代码
spring:
  ai:
    dashscope:
      api-key: sk-*  # API Key
    mcp:
      client:
        stdio:
          servers-configuration: classpath:mcp-servers.json #mcp 配置的JSON

创建 mcp-servers.json

可以在: https://bailian.console.aliyun.com/?tab=mcp#/mcp-market 中找合适的MCP 使用,例如直接搜索 MySQL就能找到 MySQL 相关的 MCP:

点击进入,按照步骤进行本地安装,需要说明的是首先要安装 node 和 npx。

安装成功后直接复制:

json 复制代码
{
  "mcpServers": {
    "mysql": {
      "command": "D:\\develop\\nodejs\\npx.cmd",
      "args": ["mysql-mcp-server"],
      "env": {
        "MYSQL_HOST": "192.168.74.100",
        "MYSQL_PORT": "3306",
        "MYSQL_USER": "dev",
        "MYSQL_PASSWORD": "Aa@123456",
        "MYSQL_DATABASE": "history"
      }
    }
  }
}

这里和官方的有点不一样。JAVA代码一直报错找不到 npx 命令,所以直接改成了 npx 的绝对路径,然后删掉了 disabled 和 autoApprove。

开发接口

配置好的 MCP 实际上对应的是 ToolCallbackProvider 类。

java 复制代码
package cn.salim.ai.controller;

import org.springframework.ai.chat.client.ChatClient;
import org.springframework.ai.tool.ToolCallbackProvider;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import reactor.core.publisher.Flux;

@RestController
@RequestMapping("ai")
public class AiController {

    private ChatClient chatClient;

    public AiController(ChatClient.Builder builder, ToolCallbackProvider toolCallbackProvider) {
    	// 大模型使用 MCP
        chatClient = builder.defaultTools(toolCallbackProvider).build();
    }

    @GetMapping
    public Flux<String> ai(String param) {
        return chatClient.prompt(param).stream().content();
    }

}

启动项目可以看到:

意味着 MCP 已经被识别到了。

测试一下

最终大模型生成的SQL是:

相关推荐
Java烘焙师8 分钟前
架构师必备:业务扩展模式选型
mysql·elasticsearch·架构·hbase·多维度查询
飞翔的佩奇19 分钟前
Java项目:基于SSM框架实现的忘忧小区物业管理系统【ssm+B/S架构+源码+数据库+毕业论文+开题报告】
java·数据库·mysql·vue·毕业设计·ssm框架·小区物业管理系统
飞睿科技22 分钟前
乐鑫代理商飞睿科技,2025年AI智能语音助手市场发展趋势与乐鑫芯片解决方案分析
人工智能
许泽宇的技术分享24 分钟前
从新闻到知识图谱:用大模型和知识工程“八步成诗”打造科技并购大脑
人工智能·科技·知识图谱
@Ryan Ding29 分钟前
MySQL主从复制与读写分离概述
android·mysql·adb
坤坤爱学习2.038 分钟前
求医十年,病因不明,ChatGPT:你看起来有基因突变
人工智能·ai·chatgpt·程序员·大模型·ai编程·大模型学
蹦蹦跳跳真可爱5891 小时前
Python----循环神经网络(Transformer ----注意力机制)
人工智能·深度学习·nlp·transformer·循环神经网络
空中湖3 小时前
tensorflow武林志第二卷第九章:玄功九转
人工智能·python·tensorflow
lishaoan773 小时前
使用tensorflow的线性回归的例子(七)
人工智能·tensorflow·线性回归
先睡5 小时前
Redis的缓存击穿和缓存雪崩
redis·spring·缓存