logo

एक्स्ट्रा ब्लॉक टाइप्स (EBT) - नया लेआउट बिल्डर अनुभव❗

एक्स्ट्रा ब्लॉक टाइप्स (EBT) - स्टाइलिश, कस्टमाइज़ेबल ब्लॉक टाइप्स: स्लाइडशो, टैब्स, कार्ड्स, एकॉर्डियन्स और कई अन्य। बैकग्राउंड, DOM बॉक्स, जावास्क्रिप्ट प्लगइन्स के लिए बिल्ट-इन सेटिंग्स। आज ही लेआउट बिल्डिंग का भविष्य अनुभव करें।

डेमो EBT मॉड्यूल्स EBT मॉड्यूल्स डाउनलोड करें

❗एक्स्ट्रा पैराग्राफ टाइप्स (EPT) - नया पैराग्राफ्स अनुभव

एक्स्ट्रा पैराग्राफ टाइप्स (EPT) - एनालॉजिकल पैराग्राफ आधारित मॉड्यूल्स का सेट।

डेमो EPT मॉड्यूल्स EPT मॉड्यूल्स डाउनलोड करें

GLightbox is a pure javascript lightbox (Colorbox alternative without jQuery)❗

It can display images, iframes, inline content and videos with optional autoplay for YouTube, Vimeo and even self-hosted videos.

Demo GLightbox Download GLightbox

स्क्रॉल

इन्सर्ट क्वेरीज़ (Insert Queries)

01/10/2025, by Ivan

Menu

इन्सर्ट क्वेरीज़ हमेशा क्वेरी बिल्डर ऑब्जेक्ट का उपयोग करके लिखी जानी चाहिए। कुछ डेटाबेस में LOB (Large OBject, जैसे MySQL में TEXT) और BLOB (Binary Large OBject) फ़ील्ड्स की विशेष हैंडलिंग की आवश्यकता होती है, इसलिए एक एब्स्ट्रैक्शन लेयर की ज़रूरत होती है ताकि अलग-अलग डेटाबेस ड्राइवर्स अपनी आवश्यक विशेष हैंडलिंग लागू कर सकें।

इन्सर्ट क्वेरीज़ insert() मेथड का उपयोग करके इस प्रकार चलाई जाती हैं:

$query = $connection->insert('mytable', $options);

यह एक इन्सर्ट क्वेरी ऑब्जेक्ट बनाता है, जो mytable टेबल में एक या अधिक रिकॉर्ड्स डालता है। ध्यान दें कि टेबल के नाम के लिए आकृति ब्रेसेस (curly braces) की आवश्यकता नहीं होती, क्योंकि क्वेरी बिल्डर इसे स्वचालित रूप से हैंडल कर लेता है।

इन्सर्ट क्वेरी ऑब्जेक्ट फ्लुएंट API का उपयोग करता है। यानी, सभी मेथड्स (सिवाय execute() के) उसी ऑब्जेक्ट को लौटाते हैं, जिससे मेथड कॉल्स को चेन करना संभव होता है। कई मामलों में इसका मतलब यह है कि क्वेरी ऑब्जेक्ट को किसी वेरिएबल में सेव करने की ज़रूरत नहीं होती।

इन्सर्ट क्वेरी ऑब्जेक्ट विभिन्न ज़रूरतों को पूरा करने के लिए कई पैटर्न्स सपोर्ट करता है। सामान्यतः वर्कफ़्लो में उन फ़ील्ड्स को निर्दिष्ट करना शामिल होता है जिनमें वैल्यू डाली जाएगी, उन वैल्यूज़ को परिभाषित करना और फिर क्वेरी चलाना। नीचे सबसे सामान्य और अनुशंसित पैटर्न्स दिए गए हैं।

संक्षिप्त रूप (Compact Form)

अधिकांश इन्सर्ट क्वेरीज़ के लिए पसंदीदा रूप संक्षिप्त रूप है:

$result = $connection->insert('mytable')
  ->fields([
    'title' => 'Example',
    'uid' => 1,
    'created' => \Drupal::time()->getRequestTime(),
  ])
  ->execute();

यह निम्नलिखित क्वेरी के बराबर होगा:

INSERT INTO {mytable} (title, uid, created) VALUES ('Example', 1, 1221717405);

ऊपर दिया गया स्निपेट इन्सर्ट प्रक्रिया के प्रमुख हिस्सों को जोड़ता है।

$connection->insert('mytable')

यह लाइन mytable टेबल के लिए एक नया इन्सर्ट क्वेरी ऑब्जेक्ट बनाती है।

  ->fields([
    'title' => 'Example',
    'uid' => 1,
    'created' => \Drupal::time()->getRequestTime(),
  ])

fields() मेथड कई प्रकार के पैरामीटर्स स्वीकार करता है, लेकिन सबसे अधिक इस्तेमाल होने वाला तरीका एक एसोसिएटिव ऐरे है। ऐरे की कीज़ वे कॉलम होते हैं जिनमें वैल्यू डाली जाएगी, और वैल्यूज़ वे मान होते हैं जिन्हें डालना है। यह निर्दिष्ट टेबल पर एक इन्सर्ट क्वेरी का परिणाम देता है।

 ->execute();

execute() मेथड क्वेरी को चलाता है। यदि इसे कॉल नहीं किया जाता, तो क्वेरी नहीं चलती।

अन्य इन्सर्ट क्वेरी मेथड्स के विपरीत, जो खुद ऑब्जेक्ट लौटाते हैं, execute() एक ऑटो-इन्क्रीमेंट फ़ील्ड (या hook_schema() में परिभाषित sequence type) का मान लौटाता है, यदि ऐसा फ़ील्ड मौजूद हो। यही कारण है कि ऊपर के उदाहरण में इसका रिटर्न वैल्यू $result को असाइन किया गया है। यदि ऑटो-इन्क्रीमेंट फ़ील्ड नहीं है, तो execute() का रिटर्न वैल्यू परिभाषित नहीं है और उस पर भरोसा नहीं किया जाना चाहिए।

अधिकतर मामलों में यह इन्सर्ट क्वेरीज़ के लिए पसंदीदा रूप है।

विस्तृत रूप (Degenerate Form)

$result = $connection->insert('mytable')
  ->fields(['title', 'uid', 'created'])
  ->values([
    'title' => 'Example',
    'uid' => 1,
    'created' => \Drupal::time()->getRequestTime(),
  ])
  ->execute();

यह पिछले क्वेरी का अधिक विस्तृत रूप है और परिणाम बिल्कुल समान होगा।

  ->fields(['title', 'uid', 'created'])

जब fields() एक इंडेक्स्ड ऐरे के साथ कॉल किया जाता है, तो यह केवल उन कॉलम्स को सेट करता है जिन्हें क्वेरी में उपयोग किया जाएगा, लेकिन उनके लिए वैल्यू सेट नहीं करता। यह आगे चलकर मल्टी-रो इन्सर्ट करने के लिए उपयोगी है।

  ->values([
    'title' => 'Example',
    'uid' => 1,
    'created' => \Drupal::time()->getRequestTime(),
  ])

यह मेथड कॉल फील्ड्स के लिए वैल्यूज़ का ऐरे सेट करता है। यह या तो एसोसिएटिव या इंडेक्स्ड ऐरे हो सकता है। यदि इंडेक्स्ड ऐरे उपयोग होता है, तो वैल्यूज़ का क्रम fields() में निर्दिष्ट फील्ड्स के क्रम से मेल खाना चाहिए। यदि एसोसिएटिव ऐरे उपयोग होता है, तो क्रम मायने नहीं रखता। पठनीयता के लिए सामान्यतः एसोसिएटिव ऐरे पसंद किया जाता है।

यह रूप दुर्लभ है, क्योंकि कॉम्पैक्ट रूप प्राथमिक होता है। अधिकतर मामलों में fields() और values() को अलग करने का एकमात्र कारण मल्टी-रो इन्सर्ट करना होता है।

मल्टी-इन्सर्ट रूप

इन्सर्ट क्वेरी ऑब्जेक्ट कई सेट्स के वैल्यूज़ भी ले सकता है। यानी values() को कई बार कॉल किया जा सकता है। यह डेटाबेस पर निर्भर करता है कि इन्हें कैसे हैंडल किया जाएगा। अधिकतर डेटाबेस में कई इन्सर्ट्स को ट्रांज़ैक्शन के भीतर चलाया जाता है ताकि डेटा इंटीग्रिटी और गति बनी रहे। MySQL में यह मल्टी-वैल्यू इन्सर्ट सिंटैक्स का उपयोग करता है।

$values = [
  [
    'title' => 'Example',
    'uid' => 1,
    'created' => \Drupal::time()->getRequestTime(),
  ],
  [
    'title' => 'Example 2',
    'uid' => 1,
    'created' => \Drupal::time()->getRequestTime(),
  ],
  [
    'title' => 'Example 3',
    'uid' => 2,
    'created' => \Drupal::time()->getRequestTime(),
  ],
];
$query = $connection->insert('mytable')->fields(['title', 'uid', 'created']);
foreach ($values as $record) {
  $query->values($record);
}
$query->execute();

ऊपर दिए गए उदाहरण में तीन इन्सर्ट्स एक साथ चलेंगे, डेटाबेस ड्राइवर के सबसे प्रभावी तरीके का उपयोग करके। ध्यान दें कि यहाँ हमने क्वेरी ऑब्जेक्ट को वेरिएबल में सेव किया ताकि हम $values पर लूप कर सकें और values() को कई बार कॉल कर सकें।

यह साधारणतया निम्नलिखित तीन क्वेरीज़ के बराबर है:

INSERT INTO {mytable} (title, uid, created) VALUES ('Example', 1, 1221717405);
INSERT INTO {mytable} (title, uid, created) VALUES ('Example2', 1, 1221717405);
INSERT INTO {mytable} (title, uid, created) VALUES ('Example3', 2, 1221717405);

ध्यान दें कि मल्टी-इन्सर्ट क्वेरीज़ में execute() का रिटर्न वैल्यू परिभाषित नहीं है और उस पर भरोसा नहीं किया जाना चाहिए, क्योंकि यह ड्राइवर पर निर्भर करता है।

सेलेक्ट क्वेरी से इन्सर्ट

यदि आप अन्य टेबल्स के परिणामों से टेबल भरना चाहते हैं, तो आपके पास दो विकल्प हैं: SELECT करके डेटा को PHP में प्रोसेस करें और नई टेबल में इन्सर्ट करें, या INSERT INTO ... SELECT FROM क्वेरी का उपयोग करें, जिसमें SELECT क्वेरी से प्रत्येक पंक्ति को INSERT में डाला जाता है।

इस उदाहरण में हम mytable टेबल बनाना चाहते हैं जिसमें सिस्टम में सभी nodes के लिए nid और username हों, जिनका प्रकार "page" है।

<?php
// SELECT क्वेरी बनाएं।
$query = $connection->select('node', 'n');
// users टेबल से join करें।
$query->join('users', 'u', 'n.uid = u.uid');
// आवश्यक फील्ड्स जोड़ें।
$query->addField('n','nid');
$query->addField('u','name');
// केवल page nodes को प्राप्त करने की शर्त।
$query->condition('type', 'page');

// इन्सर्ट चलाएं।
$connection->insert('mytable')
  ->from($query)
  ->execute();
?>

डिफ़ॉल्ट वैल्यूज़

सामान्य परिस्थितियों में, यदि आप किसी फील्ड के लिए मान निर्दिष्ट नहीं करते और टेबल स्कीमा में डिफ़ॉल्ट मान दिया गया है, तो डेटाबेस स्वतः वही मान डाल देगा। लेकिन कभी-कभी आपको स्पष्ट रूप से डेटाबेस से डिफ़ॉल्ट मान उपयोग करने के लिए कहना पड़ता है। यह तब आवश्यक होता है जब आप पूरी पंक्ति के लिए सभी डिफ़ॉल्ट मानों का उपयोग करना चाहते हैं। किसी फील्ड के लिए डिफ़ॉल्ट मान का उपयोग करने के लिए useDefaults() मेथड है।

$query->useDefaults(['field1', 'field2']);

यह क्वेरी को बताता है कि field1 और field2 के लिए डिफ़ॉल्ट मान उपयोग करे। ध्यान दें कि यदि एक ही फील्ड useDefaults() और fields() या values() में निर्दिष्ट किया गया है, तो यह एक त्रुटि होगी और एक्सेप्शन फेंका जाएगा।

$connection->insert() या $connection->query()?

यह एक अक्सर पूछा जाने वाला प्रश्न है। (इस पेज पर टिप्पणियाँ देखें।) insert() और query() में क्या अंतर है?

insert() मेथड में प्रत्येक कॉलम को फील्ड ऐरे में अलग से निर्दिष्ट किया जाता है, और कोड प्रत्येक कॉलम वैल्यू को सुरक्षित रूप से संभाल सकता है। query() में एक SQL स्ट्रिंग होती है जिसमें व्यक्तिगत कॉलम की जाँच करने का विकल्प नहीं होता। यदि आप query() को प्लेसहोल्डर्स के साथ उपयोग करते हैं, तो कॉलम वैल्यूज़ की जाँच की जा सकती है, लेकिन प्लेसहोल्डर्स केवल एक विकल्प हैं और इस बात की गारंटी नहीं होती कि SQL स्ट्रिंग में कोई मान सीधे बिना प्लेसहोल्डर के न डाला गया हो।

insert() क्वेरी को हुक्स के सेट से गुजारता है, ताकि अन्य मॉड्यूल आपके क्वेरी की जाँच और संशोधन कर सकें। यह अन्य मॉड्यूल्स के साथ काम करने का सही तरीका है। query() थोड़ा तेज़ है, क्योंकि यह क्वेरी को हुक्स से नहीं गुजारता। आप प्रोसेसिंग समय बचा सकते हैं, लेकिन आपका कोड अन्य मॉड्यूल्स को सहयोग करने की अनुमति नहीं देगा।

insert() अन्य डेटाबेस और Drupal के भविष्य के संस्करणों के साथ अधिक काम करता है।