<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:content="http://purl.org/rss/1.0/modules/content/"><channel><title>SQL MCP Server | The .NET Blog</title><link>https://thedotnetblog.com/ru/tags/sql-mcp-server/</link><description>Articles, tutorials and insights from the .NET community.</description><generator>Hugo</generator><language>ru</language><managingEditor>@thedotnetblog (The .NET Blog)</managingEditor><webMaster>@thedotnetblog</webMaster><lastBuildDate>Wed, 03 Jun 2026 00:00:00 +0000</lastBuildDate><atom:link href="https://thedotnetblog.com/ru/tags/sql-mcp-server/index.xml" rel="self" type="application/rss+xml"/><item><title>NL2SQL — это SQL-инъекция агентной эпохи</title><link>https://thedotnetblog.com/ru/news/emiliano-montesdeoca/nl2sql-agentic-sql-injection-mcp-server/</link><pubDate>Wed, 03 Jun 2026 00:00:00 +0000</pubDate><author>Emiliano Montesdeoca</author><guid>https://thedotnetblog.com/ru/news/emiliano-montesdeoca/nl2sql-agentic-sql-injection-mcp-server/</guid><description>Прежде чем позволить агенту запрашивать вашу базу данных на естественном языке, прочитайте это. NL2SQL выглядит простым, пока вы не задумаетесь о полноте схемы, недетерминизме и о том, что на самом деле решает SQL MCP Server.</description><content:encoded>&lt;p&gt;Есть версия предложения NL2SQL, которая звучит идеально: пользователи задают вопросы на естественном языке, агенты генерируют SQL, данные возвращаются. Меньше экранов, меньше запросов, меньше кода. Просто.&lt;/p&gt;
&lt;p&gt;Потом вы думаете об этом ещё пять минут.&lt;/p&gt;
&lt;h2 id="проблемы-о-которых-никто-не-говорит-на-демо"&gt;Проблемы, о которых никто не говорит на демо&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;Схемы не были созданы для объяснения вещей.&lt;/strong&gt; Криптические имена таблиц, непоследовательные имена столбцов, технически допустимые связи, которые семантически недопустимы без дополнительных предикатов — это нормально для корпоративных баз данных. Это не баги, это просто накопленная история бизнес-изменений. Но когда вы просите модель вывести намерение из схемы, которая не была создана для передачи намерения, модель попробует в любом случае. Она не сдастся. Она сгенерирует свой лучший вариант запроса и вернёт результаты с уверенностью.&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;Модели недетерминированы.&lt;/strong&gt; Задайте один и тот же вопрос об одной базе данных дважды, и вы можете получить разный SQL. Модель вычисляет вероятности, и небольшие вариации в контексте дают разные результаты. Вы не можете тестированием добиться гарантии, что агент всегда генерирует правильный запрос.&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;Пользовательская проверка не масштабируется.&lt;/strong&gt; &amp;ldquo;Просто проверяйте каждый запрос перед выполнением&amp;rdquo; звучит безопасно. Но это предполагает, что пользователи являются экспертами как в модели данных, так и в SQL — именно те люди, которым не нужен был интерфейс на естественном языке. Это также вводит когнитивную перегрузку и новый класс предвзятости подтверждения, где пользователи, перегруженные сложностью запроса, утверждают недействительные запросы вместо того, чтобы их исследовать.&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;И затем есть инъекция.&lt;/strong&gt; В традиционной разработке SQL параметризация решала проблему инъекции, потому что пользовательский ввод заполнял параметры, а не структуру SQL. С NL2SQL модель сама генерирует SQL. Подсказка, контекст схемы, история разговора и полученные данные — всё влияет на то, что выполняется. Если кто-то создаёт подсказку, которая изменяет то, что генерирует модель, это инъекция — не на уровне параметра, а на уровне генерации запроса. И в отличие от удаления таблицы (очевидно, восстановимо), инъекция NL2SQL производит запросы, возвращающие неверные результаты без видимой ошибки. Бизнес-решения принимаются на основе неверных данных.&lt;/p&gt;
&lt;h2 id="что-на-самом-деле-решает-sql-mcp-server"&gt;Что на самом деле решает SQL MCP Server&lt;/h2&gt;
&lt;p&gt;Именно здесь статья делает свой самый полезный практический вывод. Вместо того чтобы давать агенту произвольный доступ к схеме и надеяться на лучшее, SQL MCP Server предоставляет &lt;strong&gt;курируемую поверхность API&lt;/strong&gt;, построенную на основе &lt;a href="https://learn.microsoft.com/en-us/azure/data-api-builder/overview"&gt;Data API builder&lt;/a&gt;.&lt;/p&gt;
&lt;p&gt;Разница важна: агент не генерирует SQL. Он вызывает именованные конечные точки, которые возвращают предопределённые формы результатов. SQL пишется один раз, разработчиком, и является детерминированным. Недетерминизм агента ограничен выбором &lt;em&gt;какую&lt;/em&gt; конечную точку вызвать, а не построением произвольных запросов.&lt;/p&gt;
&lt;p&gt;Это аналогично тому, что параметризация сделала с SQL-инъекцией в традиционной модели приложений — вы убираете возможность создавать произвольные запросы из ненадёжного ввода.&lt;/p&gt;
&lt;h2 id="правильный-вопрос"&gt;Правильный вопрос&lt;/h2&gt;
&lt;p&gt;Статья не говорит &amp;ldquo;никогда не используйте NL2SQL.&amp;rdquo; Она говорит: будьте целенаправленны в том, &lt;em&gt;где&lt;/em&gt; вы применяете его и &lt;em&gt;что&lt;/em&gt; вы открываете. Для исследовательского анализа в контролируемой среде, с ограниченной схемой и доступом только для чтения, NL2SQL может подойти. Для производственных систем, где бизнес-решения зависят от результатов, курируемый уровень API значительно безопаснее.&lt;/p&gt;
&lt;p&gt;Честность: некоторые проблемы действительно лучше решаются структурированными запросами за именованными конечными точками, чем естественным языком в SQL. SQL MCP Server даёт вам эту возможность, не отказываясь полностью от агентного интерфейса.&lt;/p&gt;
&lt;p&gt;Оригинальная публикация: &lt;a href="https://devblogs.microsoft.com/azure-sql/sql-mcp-server-nl2sql/"&gt;Considering NL2SQL? Should your database really be the prompt? How can SQL MCP Server help?&lt;/a&gt;&lt;/p&gt;</content:encoded></item></channel></rss>