<?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/tr/tags/sql-mcp-server/</link><description>Articles, tutorials and insights from the .NET community.</description><generator>Hugo</generator><language>tr</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/tr/tags/sql-mcp-server/index.xml" rel="self" type="application/rss+xml"/><item><title>NL2SQL, Ajan Çağının SQL Enjeksiyonudur</title><link>https://thedotnetblog.com/tr/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/tr/news/emiliano-montesdeoca/nl2sql-agentic-sql-injection-mcp-server/</guid><description>Bir ajanın doğal dille veritabanınızı sorgulamasına izin vermeden önce bunu okuyun. NL2SQL, şema bütünlüğünü, belirsizliği ve SQL MCP Server'ın aslında ne çözdüğünü düşünene kadar basit görünür.</description><content:encoded>&lt;p&gt;NL2SQL sunumunun mükemmel duyulan bir versiyonu var: kullanıcılar doğal dilde sorular soruyor, ajanlar SQL üretiyor, veriler geri dönüyor. Daha az ekran, daha az sorgu, daha az kod. Basit.&lt;/p&gt;
&lt;p&gt;Sonra beş dakika daha düşünüyorsunuz.&lt;/p&gt;
&lt;h2 id="demoda-kimsenin-bahsetmediği-sorunlar"&gt;Demoda Kimsenin Bahsetmediği Sorunlar&lt;/h2&gt;
&lt;p&gt;&lt;strong&gt;Şemalar bir şeyleri açıklamak için tasarlanmamıştı.&lt;/strong&gt; Şifreli tablo adları, tutarsız sütun adları, ek koşullar olmadan anlamsal olarak geçersiz olan teknik olarak geçerli ilişkiler — bu kurumsal veritabanlarında yaygındır. Bunlar hatalar değil, sadece iş değişikliklerinin birikmiş tarihidir. Ancak bir modelden, niyeti aktarmak için tasarlanmamış bir şemadan niyet çıkarsamasını istediğinizde, model yine de deneyecektir. Vazgeçmez. En iyi sorgusunu üretir ve sonuçları güvenle döndürür.&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;Modeller deterministik değildir.&lt;/strong&gt; Aynı veritabanına aynı soruyu iki kez sorun ve farklı SQL alabilirsiniz. Model olasılıkları hesaplıyor ve bağlamdaki küçük değişiklikler farklı çıktılar üretiyor. Test ederek ajanın her zaman doğru sorguyu ürettiğine dair bir garanti elde edemezsiniz.&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;Kullanıcı incelemesi ölçeklenmiyor.&lt;/strong&gt; &amp;ldquo;Yürütmeden önce her sorguyu gözden geçirin&amp;rdquo; güvenli duyuluyor. Ama bu, kullanıcıların hem veri modelinde hem de SQL&amp;rsquo;de uzman olduğunu varsayar — tam olarak doğal dil arayüzüne ihtiyaç duymayan kişiler. Ayrıca bilişsel aşırı yükü ve yeni bir onaylama yanlılığı sınıfını da beraberinde getirir; burada sorgu karmaşıklığından bunalmış kullanıcılar araştırmak yerine geçersiz sorguları onaylar.&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;Ve sonra enjeksiyon var.&lt;/strong&gt; Geleneksel SQL geliştirmede parametreleştirme enjeksiyonu çözüyordu çünkü kullanıcı girişi SQL yapısını değil, parametreleri dolduruyordu. NL2SQL ile model SQL&amp;rsquo;in kendisini üretiyor. İstem, şema bağlamı, konuşma geçmişi ve alınan veriler, neyin yürütüldüğünü etkiliyor. Eğer biri modelin ürettiğini değiştiren bir istem oluşturursa, bu bir enjeksiyondur — parametre düzeyinde değil, sorgu üretimi düzeyinde. DROP TABLE&amp;rsquo;ın aksine (belirgin, kurtarılabilir), NL2SQL enjeksiyonları görünür hata olmaksızın yanlış sonuçlar döndüren sorgular üretir. İş kararları yanlış veriye dayanılarak alınır.&lt;/p&gt;
&lt;h2 id="sql-mcp-serverın-aslında-ne-çözdüğü"&gt;SQL MCP Server&amp;rsquo;ın Aslında Ne Çözdüğü&lt;/h2&gt;
&lt;p&gt;Makale burada en kullanışlı pratik noktasını yapıyor. Ajana rastgele şema erişimi verip en iyisini ummak yerine, SQL MCP Server &lt;a href="https://learn.microsoft.com/en-us/azure/data-api-builder/overview"&gt;Data API builder&lt;/a&gt; üzerine inşa edilmiş &lt;strong&gt;seçilmiş bir API yüzeyi&lt;/strong&gt; sunuyor.&lt;/p&gt;
&lt;p&gt;Fark önemlidir: ajan SQL üretmiyor. Önceden tanımlanmış sonuç şekilleri döndüren adlandırılmış uç noktaları çağırıyor. SQL, bir geliştirici tarafından bir kez yazılır ve deterministiktir. Ajanın belirsizliği, rastgele sorgular oluşturmakla değil, &lt;em&gt;hangi&lt;/em&gt; uç noktayı çağıracağını seçmekle sınırlıdır.&lt;/p&gt;
&lt;p&gt;Bu, parametreleştirmenin geleneksel uygulama modelinde SQL enjeksiyonu için yaptığına benzer — güvenilmeyen girişten rastgele sorgular oluşturma yeteneğini ortadan kaldırır.&lt;/p&gt;
&lt;h2 id="doğru-soru"&gt;Doğru Soru&lt;/h2&gt;
&lt;p&gt;Makale &amp;ldquo;NL2SQL&amp;rsquo;i asla kullanmayın&amp;rdquo; demiyor. &lt;em&gt;Nerede&lt;/em&gt; uyguladığınıza ve &lt;em&gt;neyi&lt;/em&gt; açığa çıkardığınıza dikkat edin, diyor. Kapsamlı şema ve salt okunur erişim ile kontrollü bir ortamda keşif analizi için NL2SQL uygun olabilir. İş kararlarının sonuçlara bağlı olduğu üretim sistemleri için, seçilmiş bir API katmanı çok daha güvenlidir.&lt;/p&gt;
&lt;p&gt;Dürüstçe söylemek gerekirse: bazı sorunlar gerçekten doğal dilden SQL&amp;rsquo;e değil, adlandırılmış uç noktaların arkasındaki yapılandırılmış sorgularla daha iyi çözülüyor. SQL MCP Server, ajantik arayüzü tamamen terk etmeden o seçeneği size sunuyor.&lt;/p&gt;
&lt;p&gt;Orijinal gönderi: &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>