SpringAI-MySQLMcp服务

1.定义

MySQLMcp的server已被别人创建好,拉下来使用即可。

MySQL MCP ( Model Context Protocol for MySQL ) 是⼀个基于 MCP 协议的服务器组件,它像 ⼀座"桥梁",连接⼤语⾔模型与 MySQL 数据库。通过它, LLM 可以直接理解⾃然语⾔查询,并⾃动 转换为 SQL 语句执⾏,返回结果。

2.安装服务

⾸先执⾏以下命令安装对应的 MCP Server 到机器上。

局部

复制代码
npm install mysql-mcp-server

全局

复制代码
npm -g install mysql-mcp-server

3.配置文件

复制代码
server:
  port: 8013
spring:
  application:
    name: ai-siliconflow-glm-mcp-sse-client
  ai:
    openai:
      base-url: https://api.siliconflow.cn
      api-key: 你的硅基流动key
      chat:
        options:
          model: "zai-org/GLM-4.6"
          temperature: 0.7
    mcp:
      client:
        name: ai-siliconflow-glm-mcp-mysql-client
        stdio:
          connections:
            mysql:
              # Windows操作系统使⽤npx.cmd,Linux和MacOS使⽤npx
              command: "npx.cmd"
              args:
                # mcp server名称
                - "mysql-mcp-server"
              env:
                # 数据库ip
                "MYSQL_HOST": "localhost"
                # 数据库服务端⼝
                "MYSQL_PORT": "3306"
                # 数据库⽤户名
                "MYSQL_USER": "root"
                # 数据库密码
                "MYSQL_PASSWORD": "123456"
                # 数据库名称
                "MYSQL_DATABASE": "jiazhong_2025_2"

4.config类

java 复制代码
package com.jiazhong.mingxing.ai.siliconflow.glm.mcp.mysql.client.config;

import jakarta.annotation.Resource;
import org.springframework.ai.chat.client.ChatClient;
import org.springframework.ai.mcp.SyncMcpToolCallbackProvider;
import org.springframework.ai.openai.OpenAiChatModel;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class ChatClientConfig {
    @Resource
    private OpenAiChatModel openAiChatModel;
    @Resource
    private SyncMcpToolCallbackProvider syncMcpToolCallbackProvider;
    @Bean("openAiChatClient")
    public ChatClient openAiChatClient(){
        return ChatClient.builder(openAiChatModel)
                .defaultToolCallbacks(syncMcpToolCallbackProvider)
                .build();
    }
}

5.controller类

java 复制代码
package com.jiazhong.mingxing.ai.siliconflow.glm.mcp.mysql.client.controller;

import jakarta.annotation.Resource;
import org.springframework.ai.chat.client.ChatClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import reactor.core.publisher.Flux;

@RestController
@RequestMapping("/mysql")
public class MySQLController {
    @Resource
    private ChatClient openAiChatClient;
    @GetMapping(value = "/a",produces = "text/html;charset=utf-8")
    public Flux<String> a(@RequestParam("question") String questiono){
        return openAiChatClient.prompt(
                        """
                                1.查询jiazhong_2025_2数据库
                                """
                )
                .user(questiono)
                .stream().content();
    }
}

6.启动类

java 复制代码
package com.jiazhong.mingxing.ai.siliconflow.glm.mcp.mysql.client;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class AiSiliconflowGlmMcpMySQLClientApplicatiion {
    public static void main(String[] args) {
        SpringApplication.run(AiSiliconflowGlmMcpMySQLClientApplicatiion.class,args);
    }
}
相关推荐
weixin_449290011 小时前
EverMemOS 访问外部(deepinfra)API接口
java·服务器·前端
zhengfei6111 小时前
Clawdbot技能合集,精彩纷呈。(Clawdbot已正式更名为Moltbot)
人工智能·语言模型
TGITCIC1 小时前
RAG不是魔法,是工程:从知识库到企业部署的硬核实践
人工智能·算法·机器学习·rag·ai agent·ai开发·rag增强检索
萤丰信息1 小时前
智慧园区:当钢筋水泥开始“光合作用”
人工智能·科技·安全·架构·智慧城市·智慧园区
运维小欣2 小时前
汽车制造业可观测性平台选型指南
人工智能·汽车
KmjJgWeb2 小时前
基于红外热成像的自动驾驶环境中的运动物体检测_YOLOv26_1
人工智能·yolo·自动驾驶
花间相见2 小时前
【AI开发】—— LangChain框架
人工智能·python·langchain
what丶k2 小时前
MySQL读写分离部署配置全解析(从原理到落地)
数据库·分布式·mysql
懒羊羊吃辣条2 小时前
问题解决方法—更新Nvidia显卡驱动后,WSL系统CUDA失效并且Anaconda环境消失
人工智能·深度学习·transformer