logo

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

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

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

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

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

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

स्क्रॉल

Drupal 7 में डेटाबेस के साथ काम — पाठ 7 — क्वेरी परिणामों की प्रोसेसिंग (fetch)

14/10/2025, by Ivan

SELECT क्वेरी हमेशा 0 या उससे अधिक रिकॉर्ड्स लौटाती है। Drupal 7 में इन परिणामों को प्रोसेस (fetch) करने के कई तरीके होते हैं — आप अपनी आवश्यकता के अनुसार कोई भी तरीका चुन सकते हैं।

सबसे सामान्य तरीका है परिणामों को foreach() लूप के माध्यम से संसाधित करना:

<?php
$result = db_query("SELECT nid, title FROM {node}");
foreach ($result as $record) {
  // प्रत्येक $record के साथ कुछ करें
  $node = node_load($record->nid);
}
?>

आप इस बात पर निर्भर करते हुए कि परिणामों के साथ क्या करना है, अन्य तरीके भी अपना सकते हैं। उदाहरण के लिए, अगली रिकॉर्ड को मैन्युअली प्राप्त करने के लिए:

<?php
$record = $result->fetch();           // डिफ़ॉल्ट रूप से ऑब्जेक्ट के रूप में प्रोसेस करता है
$record = $result->fetchObject();     // ऑब्जेक्ट के रूप में प्रोसेस करता है
$record = $result->fetchAssoc();      // एसोसिएटिव ऐरे के रूप में प्रोसेस करता है
?>

जब और रिकॉर्ड्स उपलब्ध नहीं होंगे, तो ये मेथड FALSE लौटाएँगे। बेहतर पठनीयता के लिए fetch() के बजाय fetchObject() या fetchAssoc() का उपयोग करना अधिक स्पष्ट होता है।

यदि आपको केवल एक कॉलम का मान प्राप्त करना है, तो:

<?php
$record = $result->fetchField($column_index);
?>

$column_index का डिफ़ॉल्ट मान 0 होता है (यानी पहला कॉलम)।

यदि आप जानना चाहते हैं कि कुल कितनी पंक्तियाँ लौटी हैं, तो:

<?php
$number_of_rows = $result->rowCount();
?>

यदि आप सभी रिकॉर्ड्स को एक साथ एक ऐरे में बदलना चाहते हैं, तो:

<?php
// सभी रिकॉर्ड्स को ऑब्जेक्ट्स के एसोसिएटिव ऐरे के रूप में लौटाता है
$result->fetchAll();

// किसी विशेष फ़ील्ड को कुंजी के रूप में और बाकी डेटा को मान के रूप में लौटाता है
$result->fetchAllAssoc($field);

// पहले और दूसरे कॉलम को कुंजी => मान के रूप में लौटाता है
$result->fetchAllKeyed();
$result->fetchAllKeyed(0,2); // ऐरे होगा [Field0 => Field2]
$result->fetchAllKeyed(1,0); // ऐरे होगा [Field1 => Field0]

// केवल एक कॉलम की सभी प्रविष्टियाँ एक सामान्य ऐरे में लौटाता है
$result->fetchCol();
// यदि कॉलम निर्दिष्ट किया गया है, तो उसी कॉलम के मान लौटाएगा
$result->fetchCol($column_index);
?>

ध्यान दें कि fetchAll() और fetchAllAssoc() डिफ़ॉल्ट रूप से fetch मोड का पालन करते हैं, लेकिन आप इन्हें नया fetch मोड पास करके बदल सकते हैं। fetchAll() के लिए यह पहला पैरामीटर होगा, और fetchAllAssoc() के लिए दूसरा।

चूंकि PHP में ऑब्जेक्ट्स पर मेथड चेनिंग समर्थित है, आप मध्यवर्ती वेरिएबल $result को छोड़ सकते हैं और क्वेरी के परिणामों को सीधे प्रोसेस कर सकते हैं:

<?php
// nid और title को एक एसोसिएटिव ऐरे के रूप में प्राप्त करें
$nodes = db_query("SELECT nid, title FROM {node}")->fetchAllKeyed();

// एकल रिकॉर्ड को ऑब्जेक्ट के रूप में प्राप्त करें
$node = db_query("SELECT * FROM {node} WHERE nid = :nid", array(':nid' => $nid))->fetchObject();

// केवल एक फ़ील्ड (title) का मान प्राप्त करें
$title = db_query("SELECT title FROM {node} WHERE nid = :nid", array(':nid' => $nid))->fetchField();
?>