<?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/fr/tags/sql-mcp-server/</link><description>Articles, tutorials and insights from the .NET community.</description><generator>Hugo</generator><language>fr</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/fr/tags/sql-mcp-server/index.xml" rel="self" type="application/rss+xml"/><item><title>NL2SQL est l'injection SQL de l'ère agentique</title><link>https://thedotnetblog.com/fr/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/fr/news/emiliano-montesdeoca/nl2sql-agentic-sql-injection-mcp-server/</guid><description>Avant de laisser un agent interroger votre base de données en langage naturel, lisez ceci. NL2SQL semble simple jusqu'à ce que vous réfléchissiez à la complétude du schéma, à l'indéterminisme et à ce que SQL MCP Server résout vraiment.</description><content:encoded>&lt;p&gt;Il existe une version du discours NL2SQL qui semble parfaite : les utilisateurs posent des questions en langage naturel, les agents génèrent du SQL, les données reviennent. Moins d&amp;rsquo;écrans, moins de requêtes, moins de code. Simple.&lt;/p&gt;
&lt;p&gt;Puis vous y réfléchissez cinq minutes de plus.&lt;/p&gt;
&lt;h2 id="les-problèmes-dont-personne-ne-parle-dans-la-démo"&gt;Les problèmes dont personne ne parle dans la démo&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;Les schémas n&amp;rsquo;ont pas été conçus pour expliquer les choses.&lt;/strong&gt; Noms de tables cryptiques, noms de colonnes incohérents, relations techniquement valides mais sémantiquement invalides sans prédicats supplémentaires — c&amp;rsquo;est normal dans les bases de données d&amp;rsquo;entreprise. Ce ne sont pas des bugs, c&amp;rsquo;est simplement l&amp;rsquo;histoire accumulée des changements métier. Mais quand vous demandez à un modèle d&amp;rsquo;inférer l&amp;rsquo;intention d&amp;rsquo;un schéma qui n&amp;rsquo;a pas été conçu pour communiquer l&amp;rsquo;intention, le modèle essaiera quand même. Il ne s&amp;rsquo;arrêtera pas. Il générera sa meilleure requête et retournera des résultats avec assurance.&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;Les modèles ne sont pas déterministes.&lt;/strong&gt; Posez la même question sur la même base de données deux fois et vous pourriez obtenir du SQL différent. Le modèle calcule des probabilités, et de légères variations de contexte produisent des sorties différentes. Vous ne pouvez pas tester votre chemin vers une garantie que l&amp;rsquo;agent génère toujours la bonne requête.&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;La révision par l&amp;rsquo;utilisateur ne passe pas à l&amp;rsquo;échelle.&lt;/strong&gt; &amp;ldquo;Vérifiez simplement chaque requête avant l&amp;rsquo;exécution&amp;rdquo; semble sûr. Mais cela suppose que les utilisateurs sont des experts à la fois dans le modèle de données et en SQL — exactement les personnes qui n&amp;rsquo;avaient pas besoin de l&amp;rsquo;interface en langage naturel. Cela introduit également une surcharge cognitive et une nouvelle classe de biais de confirmation, où les utilisateurs submergés par la complexité des requêtes approuvent des requêtes invalides plutôt que de les investiguer.&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;Et puis il y a l&amp;rsquo;injection.&lt;/strong&gt; Dans le développement SQL traditionnel, la paramétrisation a résolu l&amp;rsquo;injection parce que la saisie utilisateur remplissait des paramètres, pas la structure SQL. Avec NL2SQL, le modèle génère le SQL lui-même. Le prompt, le contexte du schéma, l&amp;rsquo;historique de conversation et les données récupérées influencent tous ce qui est exécuté. Si quelqu&amp;rsquo;un élabore un prompt qui change ce que le modèle génère, c&amp;rsquo;est de l&amp;rsquo;injection — pas au niveau des paramètres, mais au niveau de la génération des requêtes. Et contrairement à la suppression d&amp;rsquo;une table (évident, récupérable), l&amp;rsquo;injection NL2SQL produit des requêtes qui retournent des résultats incorrects sans aucune erreur visible. Des décisions métier sont prises sur de mauvaises données.&lt;/p&gt;
&lt;h2 id="ce-que-sql-mcp-server-résout-réellement"&gt;Ce que SQL MCP Server résout réellement&lt;/h2&gt;
&lt;p&gt;C&amp;rsquo;est là que l&amp;rsquo;article fait son point pratique le plus utile. Plutôt que de donner à un agent un accès arbitraire au schéma et d&amp;rsquo;espérer le meilleur, SQL MCP Server expose une &lt;strong&gt;surface API organisée&lt;/strong&gt; construite sur &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;La différence est importante : l&amp;rsquo;agent ne génère pas de SQL. Il appelle des endpoints nommés qui retournent des formes de résultat prédéfinies. Le SQL est écrit une fois, par un développeur, et est déterministe. Le non-déterminisme de l&amp;rsquo;agent se limite à choisir &lt;em&gt;quel&lt;/em&gt; endpoint appeler, pas à construire des requêtes arbitraires.&lt;/p&gt;
&lt;p&gt;C&amp;rsquo;est analogue à ce que la paramétrisation a fait pour l&amp;rsquo;injection SQL dans le modèle d&amp;rsquo;application traditionnel — vous supprimez la capacité de construire des requêtes arbitraires à partir d&amp;rsquo;entrées non fiables.&lt;/p&gt;
&lt;h2 id="la-bonne-question"&gt;La bonne question&lt;/h2&gt;
&lt;p&gt;L&amp;rsquo;article ne dit pas &amp;ldquo;n&amp;rsquo;utilisez jamais NL2SQL.&amp;rdquo; Il dit : soyez délibéré sur &lt;em&gt;où&lt;/em&gt; vous l&amp;rsquo;appliquez et &lt;em&gt;ce que&lt;/em&gt; vous exposez. Pour une analyse exploratoire dans un environnement contrôlé, avec un schéma limité et un accès en lecture seule, NL2SQL pourrait convenir. Pour les systèmes de production où les décisions métier dépendent des résultats, une couche API organisée est significativement plus sûre.&lt;/p&gt;
&lt;p&gt;Honnêteté : certains problèmes sont vraiment mieux résolus avec des requêtes structurées derrière des endpoints nommés qu&amp;rsquo;avec du langage naturel vers SQL. SQL MCP Server vous donne cette option sans abandonner entièrement l&amp;rsquo;interface agentique.&lt;/p&gt;
&lt;p&gt;Publication originale : &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>