Sqlserver
 sql >> डेटाबेस >  >> RDS >> Sqlserver

टी-एसक्यूएल इंसर्ट स्टेटमेंट में रो कंस्ट्रक्टर सिंटैक्स का उपयोग करने के क्या लाभ हैं?

हां, इनके बीच प्रदर्शन में काफी अंतर है:

declare @numbers table (n int not null primary key clustered);

insert into @numbers (n)
values (0)
     , (1)
     , (2)
     , (3)
     , (4);

और

declare @numbers table (n int not null primary key clustered);

insert into @numbers (n) values (0);
insert into @numbers (n) values (1);
insert into @numbers (n) values (2);
insert into @numbers (n) values (3);
insert into @numbers (n) values (4);

तथ्य यह है कि हर एक insert स्टेटमेंट का अपना निहित लेनदेन है इसकी गारंटी देता है। आप प्रत्येक कथन के लिए निष्पादन योजनाओं को देखकर या set statistics time on; का उपयोग करके निष्पादन के समय को देखकर आसानी से स्वयं को साबित कर सकते हैं। . प्रत्येक व्यक्तिगत इंसर्ट के संदर्भ में "सेटिंग अप" और "फायर डाउन" के साथ एक निश्चित लागत जुड़ी हुई है और दूसरी क्वेरी को इस दंड का पांच बार भुगतान करना पड़ता है जबकि पहला केवल एक बार भुगतान करता है।

सूची पद्धति न केवल अधिक कुशल है बल्कि आप इसका उपयोग व्युत्पन्न तालिका बनाने के लिए भी कर सकते हैं:

select *
from (values
    (0)
  , (1)
  , (2)
  , (3)
  , (4)
) as Numbers (n);

यह प्रारूप लगभग 1,000 मूल्य सीमा प्राप्त करता है और आपको सम्मिलित होने से पहले अपनी सूची में शामिल होने और फ़िल्टर करने की अनुमति देता है। कोई यह भी देख सकता है कि हम insert . के लिए बाध्य नहीं हैं बिल्कुल बयान! एक वास्तविक तालिका के रूप में, इस निर्माण का उपयोग कहीं भी किया जा सकता है एक तालिका संदर्भ मान्य होगा।



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. सम्मिलित रिकॉर्ड की आईडी पुनर्प्राप्त करें:Php और MS SQL सर्वर

  2. SQL 2008 HierarchyID NHibernate में समर्थन करता है

  3. कॉलम में डिफ़ॉल्ट मान सेट करें यदि SQL 2008 में शर्त पूरी होती है

  4. एक वर्चर डेटा प्रकार को डेटाटाइम डेटा प्रकार में बदलने के परिणामस्वरूप एक आउट-ऑफ-रेंज मान होता है

  5. अद्वितीय वृद्धिशील मानों के साथ तालिका में इंट कॉलम अपडेट करें