कभी-कभी आपका MySQLi कोड त्रुटि mysqli_fetch_assoc() expects parameter...
, Call to a member function bind_param()...
या इसी तरह का उत्पादन करता है । या बिना किसी त्रुटि के भी, लेकिन क्वेरी सभी समान काम नहीं करती है। इसका मतलब है कि आपकी क्वेरी निष्पादित करने में विफल रही।
हर बार जब कोई क्वेरी विफल होती है, तो MySQL में एक त्रुटि संदेश होता है जो इसका कारण बताता है । दुर्भाग्य से, डिफ़ॉल्ट रूप से ऐसी त्रुटियां PHP में स्थानांतरित नहीं होती हैं, और आपको जो भी मिला है वह ऊपर उल्लिखित एक गुप्त त्रुटि संदेश है। इसलिए MySQL त्रुटियों को रिपोर्ट करने के लिए PHP और MySQLi को कॉन्फ़िगर करना बहुत महत्वपूर्ण है। और एक बार जब आप त्रुटि संदेश प्राप्त करते हैं, तो इसे ठीक करना केक का एक टुकड़ा होगा।
MySQLi में त्रुटि संदेश कैसे प्राप्त करें?
सबसे पहले, आपके सभी वातावरणों में MySQLi कनेक्ट होने से पहले हमेशा यह रेखा होनी चाहिए:
mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);
उसके बाद सभी MySQL त्रुटियों को PHP अपवादों में स्थानांतरित किया जाएगा। बदले में अपवाद छोड़ दिया, एक PHP घातक त्रुटि बनाता है। इस प्रकार, MySQL त्रुटि के मामले में, आपको एक पारंपरिक PHP त्रुटि मिलेगी। जो आपको तुरंत त्रुटि के कारण से अवगत कराएगा। और एक स्टैक ट्रेस आपको उस सटीक स्थान पर ले जाएगा जहां त्रुटि हुई थी।
विभिन्न वातावरणों में PHP को कैसे कॉन्फ़िगर करें
यहाँ PHP त्रुटि रिपोर्टिंग पर मेरे लेख का सार है :
एक विकास और लाइव सर्वर पर त्रुटियों की रिपोर्ट करना अलग होना चाहिए। एक डेवलपमेंट सर्वर पर ऑन-स्क्रीन में दिखाई गई त्रुटियों का होना सुविधाजनक है, लेकिन एक लाइव सर्वर एरर मैसेज के बजाय लॉग इन करना होगा, इसलिए आप उन्हें बाद में एरर लॉग में पा सकते हैं।
इसलिए, आपको निम्न मानों के लिए संगत कॉन्फ़िगरेशन विकल्प सेट करना होगा:
एक विकास सर्वर पर
error_reporting
E_ALL
मूल्य पर सेट किया जाना चाहिए ;
log_errors
1 पर सेट होना चाहिए (यह एक विकास पीसी पर भी लॉग करने के लिए सुविधाजनक है)
display_errors
1 पर सेट होना चाहिए
एक प्रोडक्शन सर्वर पर
error_reporting
E_ALL
मूल्य पर सेट किया जाना चाहिए ;
log_errors
1 पर सेट होना चाहिए
display_errors
0 पर सेट होना चाहिए
वास्तव में इसका उपयोग कैसे करें?
बस किसी भी कोड को हटा दें जो त्रुटि के लिए मैन्युअल रूप से जांच करता है , उन सभी को or die()
, if ($result)
और ऐसे। बस अपने डेटाबेस इंटरैक्शन कोड को तुरंत लिखें:
$stmt = $this->con->prepare("INSERT INTO table(name, quantity) VALUES (?,?)");
$stmt->bind_param("si", $name, $quantity);
$stmt->execute();
फिर से, बिना किसी शर्त के । यदि कोई त्रुटि होती है, तो इसे आपके कोड में किसी अन्य त्रुटि के रूप में माना जाएगा। उदाहरण के लिए, एक विकास पीसी पर यह सिर्फ ऑन-स्क्रीन दिखाई देगा, जबकि एक लाइव साइट पर इसे प्रोग्रामर के लिए लॉग इन किया जाएगा, जबकि उपयोगकर्ता की सुविधा के लिए आप एक त्रुटि हैंडलर का उपयोग कर सकते हैं (लेकिन यह एक अलग कहानी है जो विषय के लिए बंद है MySQLi, लेकिन आप ऊपर दिए गए लेख में इसके बारे में पढ़ सकते हैं)।
आपको प्राप्त त्रुटि संदेश के साथ क्या करना है?
सबसे पहले आपको समस्या क्वेरी का पता लगाना होगा। त्रुटि संदेश में फ़ाइल नाम और सटीक स्थान की पंक्ति संख्या होती है जहाँ त्रुटि हुई। सरल कोड के लिए यह पर्याप्त है, लेकिन यदि आपका कोड फ़ंक्शंस या क्लासेस का उपयोग कर रहा है, तो आपको समस्या क्वेरी का पता लगाने के लिए स्टैक ट्रेस का पालन करना पड़ सकता है ।
त्रुटि संदेश प्राप्त करने के बाद, आपको इसे पढ़ना और समझना होगा। यह बहुत स्पष्ट लगता है यदि कृपालु नहीं है, लेकिन शिक्षार्थी अक्सर इस तथ्य को नजरअंदाज करते हैं कि त्रुटि संदेश केवल एक अलार्म संकेत नहीं है, लेकिन इसमें वास्तव में समस्या का विस्तृत विवरण है । और आपको केवल त्रुटि संदेश पढ़ने और समस्या को ठीक करने की आवश्यकता है।
- कहो, अगर यह कहता है कि एक विशेष तालिका मौजूद नहीं है, तो आपको वर्तनी, टाइपो, पत्र मामले की जांच करनी होगी। इसके अलावा, आपको यह सुनिश्चित करना होगा कि आपकी PHP स्क्रिप्ट एक सही डेटाबेस से कनेक्ट हो
- या, अगर यह कहता है कि एसक्यूएल सिंटैक्स में कोई त्रुटि है, तो आपको अपने एसक्यूएल की जांच करनी होगी। और समस्या स्थान त्रुटि संदेश में उद्धृत क्वेरी भाग से ठीक पहले है।
यदि आपको त्रुटि संदेश समझ में नहीं आता है, तो उसे Google पर आज़माएं। और परिणामों को ब्राउज़ करते समय, उत्तर देने के लिए चिपके रहें जो त्रुटि को स्पष्ट रूप से हल करने के बजाय बताते हैं। एक समाधान आपके विशेष मामले में काम नहीं कर सकता है, लेकिन स्पष्टीकरण आपको समस्या को समझने में मदद करेगा और आपको समस्या को स्वयं ठीक करने में सक्षम करेगा।
आपको त्रुटि संदेश पर भी भरोसा करना होगा। यदि यह कहता है कि टोकन की संख्या बाध्य चर की संख्या से मेल नहीं खाती है तो ऐसा है। अनुपस्थित तालिकाओं या स्तंभों के लिए भी यही होता है। पसंद को देखते हुए, चाहे वह आपकी अपनी गलती हो या त्रुटि संदेश गलत हो, हमेशा पूर्व से चिपके रहें। फिर से यह कृपालु लगता है, लेकिन इस साइट पर सैकड़ों प्रश्न इस सलाह को बेहद उपयोगी साबित करते हैं।
उन चीजों की एक सूची जो आपको कभी भी त्रुटि रिपोर्टिंग के संबंध में नहीं करनी चाहिए
- कभी भी एक त्रुटि दमन ऑपरेटर (
@
) का उपयोग न करें ! यह एक प्रोग्रामर को त्रुटि संदेश पढ़ने में असमर्थ बनाता है और इसलिए त्रुटि को ठीक करने में असमर्थ होता है
- बिना स्क्रीन पर त्रुटि संदेश को प्रिंट करने के लिए या किसी अन्य फ़ंक्शन का उपयोग न करें
die()
या न करें echo
। PHP अपने आप त्रुटियों की रिपोर्ट कर सकती है और इसे सही तरीके से करना पर्यावरण पर निर्भर करता है - तो बस इसे PHP के लिए छोड़ दें।
- मैन्युअल रूप से (जैसे
if($result)
) क्वेरी परिणाम का परीक्षण करने के लिए एक शर्त न जोड़ें । त्रुटि अपवाद सक्षम करने से ऐसी स्थिति बस बेकार हो जाएगी।
try..catch
त्रुटि संदेश गूँजने के लिए ऑपरेटर का उपयोग न करें । लेन-देन रोलबैक की तरह कुछ त्रुटि से निपटने के लिए इस ऑपरेटर का उपयोग किया जाना चाहिए। लेकिन कभी भी त्रुटियों को रिपोर्ट करने के लिए इसका उपयोग न करें - जैसा कि हमने ऊपर सीखा, PHP पहले से ही कर सकता है, सही तरीका।
पुनश्च
कभी-कभी कोई त्रुटि नहीं होती है लेकिन कोई परिणाम नहीं होता है। फिर इसका मतलब है, डेटाबेस में आपके मापदंड से मेल खाने के लिए कोई डेटा नहीं है । इस मामले में आपको इस तथ्य को स्वीकार करना होगा, भले ही आप डेटा को शपथ लें और मानदंड सभी सही हों। वो नहीं हैं। आपको उन्हें फिर से जांचना होगा। मुझे एक लेख मिला है जो इस मामले में मदद कर सकता है, डेटाबेस इंटरैक्शन को कैसे डीबग करें । हालांकि यह पीडीओ के लिए लिखा गया है, लेकिन सिद्धांत समान है। बस इस अनुदेश चरण का पालन करें और या तो आपकी समस्या हल हो गई है या स्टैक ओवरफ्लो के लिए एक उत्तर देने योग्य प्रश्न है।
$mysqli
चर की शुरुआत कहां से कर रहे हैं ?