Сервер Model Context Procotol (MCP) на основе Java для JDBC
Легкий сервер MCP (Model Context Protocol) для JDBC, созданный с помощью Quakrus . Этот сервер совместим с СУБД Virtuoso и другими бэкэндами СУБД, имеющими драйверы JDBC.
Функции
- Получить схемы : извлечь и составить список всех имен схем из подключенной базы данных.
- Получить таблицы : извлечь информацию о таблицах для определенных схем или всех схем.
- Опишите таблицу : создайте подробное описание структур таблиц, включая:
- Имена столбцов и типы данных
- Атрибуты, допускающие значение NULL
- Первичные и внешние ключи
- Поиск таблиц : фильтрация и извлечение таблиц на основе подстрок имен.
- Выполнение хранимых процедур : специфическая функция Virtuoso! Выполнение хранимых процедур и получение результатов.
- Выполнение запросов :
- Формат результата JSONL: оптимизирован для структурированных ответов.
- Формат таблицы Markdown: идеально подходит для составления отчетов и визуализации.
Предпосылки
Для сервера MCP требуется Java 21 или выше.
Установка
Клонируйте этот репозиторий:
Переменные среды
Обновите свой .env
, переопределив эти значения по умолчанию в соответствии со своими предпочтениями:
Конфигурация
Для пользователей Claude Desktop : добавьте следующее в claude_desktop_config.json
:
Для пользователей Claude Desktop, использующих другие драйверы JDBC или комбинацию драйверов: добавьте следующее в claude_desktop_config.json
:
Использовать
Предоставляемые инструменты
После успешной установки клиентским приложениям MCP будут доступны следующие инструменты.
Обзор
имя | описание |
---|---|
jdbc_get_schemas | Перечислить схемы баз данных, доступные для подключенной системы управления базами данных (СУБД). |
jdbc_get_tables | Список таблиц, связанных с выбранной схемой базы данных. |
jdbc_describe_table | Предоставьте описание таблицы, связанной с указанной схемой базы данных. Это включает информацию об именах столбцов, типах данных, обработке нулей, автоинкременте, первичном ключе и внешних ключах. |
jdbc_filter_table_names | Список таблиц на основе шаблона подстроки из поля ввода q , связанного с выбранной схемой базы данных. |
jdbc_query_database | Выполнить SQL-запрос и вернуть результаты в формате JSONL. |
jdbc_execute_query | Выполнить SQL-запрос и вернуть результаты в формате JSONL. |
jdbc_execute_query_md | Выполнить SQL-запрос и вернуть результаты в формате таблицы Markdown. |
jdbc_spasql_query | Специфическая функция Virtuoso! Выполнение запроса SPASQL и возврат результатов. |
jdbc_sparql_query | Специфическая функция Virtuoso! Выполнение запроса SPARQL и возврат результатов. |
jdbc_virtuoso_support_ai | Специальная функция Virtuoso! Взаимодействуйте с LLM через помощника/агента поддержки Virtuoso. |
Подробное описание
jdbc_get_schemas
- Извлечь и вернуть список всех имен схем из подключенной базы данных.
- Входные параметры:
user
(строка, необязательно): Имя пользователя базы данных. По умолчанию"demo"
.password
(строка, необязательно): Пароль базы данных. По умолчанию"demo"
.url
(строка, необязательно): строка подключения URL-адреса JDBC.
- Возвращает массив строк JSON с именами схем.
jdbc_get_tables
- Извлечь и вернуть список, содержащий информацию о таблицах в указанной схеме. Если схема не указана, используется схема соединения по умолчанию.
- Входные параметры:
schema
(строка, необязательно): Схема базы данных для фильтрации таблиц. По умолчанию используется соединение по умолчанию.user
(строка, необязательно): Имя пользователя базы данных. По умолчанию"demo"
.password
(строка, необязательно): Пароль базы данных. По умолчанию"demo"
.url
(строка, необязательно): строка подключения URL-адреса JDBC.
- Возвращает строку JSON, содержащую информацию о таблице (например,
TABLE_CAT
,TABLE_SCHEM
,TABLE_NAME
,TABLE_TYPE
).
jdbc_filter_table_names
- Фильтрует и возвращает информацию о таблицах, имена которых содержат определенную подстроку.
- Входные параметры:
q
(строка, обязательно): подстрока для поиска в именах таблиц.schema
(строка, необязательно): Схема базы данных для фильтрации таблиц. По умолчанию используется соединение по умолчанию.user
(строка, необязательно): Имя пользователя базы данных. По умолчанию"demo"
.password
(строка, необязательно): Пароль базы данных. По умолчанию"demo"
.url
(строка, необязательно): строка подключения URL-адреса JDBC.
- Возвращает строку JSON, содержащую информацию для сопоставления таблиц.
jdbc_describe_table
- Извлечение и возврат подробной информации о столбцах определенной таблицы.
- Входные параметры:
schema
(строка, обязательно): имя схемы базы данных, содержащей таблицу.table
(строка, обязательно): Имя таблицы, которую нужно описать.user
(строка, необязательно): Имя пользователя базы данных. По умолчанию"demo"
.password
(строка, необязательно): Пароль базы данных. По умолчанию"demo"
.url
(строка, необязательно): строка подключения URL-адреса JDBC.
- Возвращает строку JSON, описывающую столбцы таблицы (например,
COLUMN_NAME
,TYPE_NAME
,COLUMN_SIZE
,IS_NULLABLE
).
jdbc_query_database
- Выполнить стандартный SQL-запрос и вернуть результаты в формате JSON.
- Входные параметры:
query
(строка, обязательно): строка SQL-запроса для выполнения.user
(строка, необязательно): Имя пользователя базы данных. По умолчанию"demo"
.password
(строка, необязательно): Пароль базы данных. По умолчанию"demo"
.url
(строка, необязательно): строка подключения URL-адреса JDBC.
- Возвращает результаты запроса в виде строки JSON.
jdbc_query_database_md
- Выполнить стандартный SQL-запрос и вернуть результаты, отформатированные в виде таблицы Markdown.
- Входные параметры:
query
(строка, обязательно): строка SQL-запроса для выполнения.user
(строка, необязательно): Имя пользователя базы данных. По умолчанию"demo"
.password
(строка, необязательно): Пароль базы данных. По умолчанию"demo"
.url
(строка, необязательно): строка подключения URL-адреса JDBC.
- Возвращает результаты запроса в виде строки таблицы Markdown.
jdbc_query_database_jsonl
- Выполнить стандартный SQL-запрос и вернуть результаты в формате строк JSON (JSONL) (один объект JSON на строку).
- Входные параметры:
query
(строка, обязательно): строка SQL-запроса для выполнения.user
(строка, необязательно): Имя пользователя базы данных. По умолчанию"demo"
.password
(строка, необязательно): Пароль базы данных. По умолчанию"demo"
.url
(строка, необязательно): строка подключения URL-адреса JDBC.
- Возвращает результаты запроса в виде строки JSONL.
jdbc_spasql_query
- Специфическая функция Virtuoso!
- Выполнение запроса SPASQL (гибрид SQL/SPARQL) с возвратом результатов.
- Входные параметры:
query
(строка, обязательно): строка запроса SPASQL.max_rows
(число, необязательно): Максимальное количество возвращаемых строк. По умолчанию20
.timeout
(число, необязательно): Тайм-аут запроса в миллисекундах. По умолчанию30000
(т.е. 30 секунд).user
(строка, необязательно): Имя пользователя базы данных. По умолчанию"demo"
.password
(строка, необязательно): Пароль базы данных. По умолчанию"demo"
.url
(строка, необязательно): строка подключения URL-адреса JDBC.
- Возвращает результат вызова базовой хранимой процедуры (например,
Demo.demo.execute_spasql_query
).
jdbc_sparql_query
- Специфическая функция Virtuoso!
- Выполнить запрос SPARQL и вернуть результаты.
- Входные параметры:
query
(строка, обязательно): строка запроса SPARQL.format
(string, необязательно): Желаемый формат результата. По умолчанию'json'
.timeout
(число, необязательно): Тайм-аут запроса в миллисекундах. По умолчанию30000
(т.е. 30 секунд).user
(строка, необязательно): Имя пользователя базы данных. По умолчанию"demo"
.password
(строка, необязательно): Пароль базы данных. По умолчанию"demo"
.url
(строка, необязательно): строка подключения URL-адреса JDBC.
- Возвращает результат вызова базовой функции (например,
"UB".dba."sparqlQuery"
).
jdbc_virtuoso_support_ai
- Специфическая функция Virtuoso!
- Использует специфичную для Virtuoso функцию AI Assistant, передавая подсказку и необязательный ключ API.
- Входные параметры:
prompt
(строка, обязательно): текст подсказки для функции ИИ.api_key
(string, необязательно): API-ключ для службы AI. По умолчанию"none"
.user
(строка, необязательно): Имя пользователя базы данных. По умолчанию"demo"
.password
(строка, необязательно): Пароль базы данных. По умолчанию"demo"
.url
(строка, необязательно): строка подключения URL-адреса JDBC.
- Возвращает результат вызова функции AI Support Assistant (например,
DEMO.DBA.OAI_VIRTUOSO_SUPPORT_AI
).
Базовое использование и устранение неполадок
MCP Inspector подключается к драйверу ODBC Virtuoso
Для базового использования клиента MCP и устранения неполадок используйте MCP Inspector следующим образом:
- Установите MCP Inspector:
- Запустите инспектор:
Перейдите по URL-адресу, возвращенному инспектором, для устранения неполадок взаимодействия с сервером MCP.
MCP Inspector Подключение к дополнительным драйверам
Для базового использования клиента MCP и устранения неполадок используйте MCP Inspector следующим образом:
- Установите драйвер(ы) JDBC, убедившись, что их файлы JAR зарегистрированы в виртуальной машине Java (JVM) операционной системы хоста через
$CLASSPATH
. Например: - Запустите инспектор, используя следующие аргументы командной строки:
Пример использования на основе драйверов Oracle и Informix
- Предположим, что имеется следующая информация о драйвере JDBC:
- Шаблон URL-адреса драйвера Oracle JDBC
- Шаблон URL-адреса драйвера Informix JDBC
- Шаблон URL-адреса драйвера Oracle JDBC
- Установите драйверы JDBC Oracle (
ojdbc17.jar
) и/или Informix (jdbc-15.0.0.1.1.jar
) и убедитесь, что их файлы JAR зарегистрированы в виртуальной машине Java (JVM) операционной системы хоста через$CLASSPATH
. Например: - Запустите инспектор, используя следующие аргументы командной строки:
- Получите доступ к URL-адресу, возвращенному инспектором, а затем используйте операцию
jdbc_execute_query
для запроса целевой базы данных, указав фактические значения для следующих шаблонов полей ввода:- URL-адрес JDBC
- Пользователь
- Пароль
- Запрос
This server cannot be installed
hybrid server
The server is able to function both locally and remotely, depending on the configuration or use case.
Сервер OpenLink MCP для JDBC
Related MCP Servers
- -securityAlicense-qualityMCP to access any database accessible via JDBC such as Postgres, Oracle, mysql, mariadb, sqlite etc.Last updated -122Apache 2.0
- GoApache 2.0
- -securityAlicense-qualityOpen source MCP server specializing in easy, fast, and secure tools for Databases.Last updated -977GoApache 2.0
- Python