मारियाबडी - नल मान
NULL मानों के साथ काम करते समय, याद रखें कि वे अज्ञात मूल्य हैं। वे खाली तार या शून्य नहीं हैं, जो मान्य मूल्य हैं। तालिका निर्माण में, स्तंभ विनिर्देश उन्हें शून्य मान स्वीकार करने या उन्हें अस्वीकार करने के लिए सेट करने की अनुमति देते हैं। बस एक NULL या NOT NULL क्लॉज का उपयोग करें। इसमें एक आईडी नंबर जैसी रिकॉर्ड जानकारी गुम होने के मामलों में आवेदन हैं।
उपयोगकर्ता-परिभाषित चर में स्पष्ट असाइनमेंट तक NULL का मान है। संग्रहीत नियमित पैरामीटर और स्थानीय चर NULL का मान सेट करने की अनुमति देते हैं। जब किसी स्थानीय चर का कोई डिफ़ॉल्ट मान नहीं होता है, तो उसका NULL का मान होता है।
NULL केस-असंवेदनशील है, और इसमें निम्न उपनाम हैं -
- UNKNOWN (एक बुलियन मूल्य)
- \N
नाल संचालक
मानक तुलना संचालकों को NULL (जैसे, =,>,> =, <=, <, या! =) के साथ उपयोग नहीं किया जा सकता है क्योंकि NULL मान के साथ सभी तुलना NULL, सही या गलत नहीं है। NULL या संभवतः इसके साथ तुलना करने के लिए "<=>" (NULL-SAFE) ऑपरेटर का उपयोग करना चाहिए।
अन्य उपलब्ध ऑपरेटर हैं -
IS NULL - यह एक NULL मान के लिए परीक्षण करता है।
पूर्ण नहीं है - यह एक पूर्ण मूल्य की अनुपस्थिति की पुष्टि करता है।
ISNULL - यह एक NULL मान की खोज पर 1 का मान लौटाता है, और इसकी अनुपस्थिति में 0।
COALESCE - यह किसी सूची का पहला गैर-पूर्ण मान लौटाता है, या किसी के अभाव में NULL मान लौटाता है।
पूर्ण मानों को क्रमबद्ध करना
सॉर्टिंग कार्यों में, NULL मानों का मूल्य सबसे कम होता है, इसलिए DESC ऑर्डर के निचले भाग में NULL मान होते हैं। MariaDB NULL मान के लिए उच्च मान सेट करने की अनुमति देता है।
इसे करने के दो तरीके हैं जैसे कि नीचे दिखाया गया है -
SELECT column1 FROM product_tbl ORDER BY ISNULL(column1), column1;
दूसरा तरीका -
SELECT column1 FROM product_tbl ORDER BY IF(column1 IS NULL, 0, 1), column1 DESC;
पूर्ण कार्य
जब आम तौर पर कोई पैरामीटर NULL होता है तो फंक्शंस NULL आउटपुट करते हैं। हालाँकि, विशेष रूप से NULL मान प्रबंधित करने के लिए डिज़ाइन किए गए कार्य हैं। वे हैं -
IFNULL()- अगर पहला एक्सप्रेशन NULL नहीं है तो वह उसे लौटा देता है। जब यह NULL का मूल्यांकन करता है, तो यह दूसरी अभिव्यक्ति देता है।
NULLIF() - यह NULL लौटाता है जब तुलनात्मक भाव समान होते हैं, यदि नहीं, तो यह पहली अभिव्यक्ति देता है।
एसयूएम और एवीजी जैसे कार्य NULL मूल्यों की उपेक्षा करते हैं।
पूर्ण मानों को सम्मिलित करना
NULL घोषित किए गए कॉलम में NULL मान सम्मिलित करने पर, एक त्रुटि उत्पन्न होती है। डिफ़ॉल्ट SQL मोड में, एक NULL कॉलम इसके बजाय डेटा प्रकार के आधार पर डिफ़ॉल्ट मान नहीं डालेगा।
जब कोई फ़ील्ड TIMESTAMP, AUTO_INCREMENT, या वर्चुअल कॉलम होता है, तो MariaDB NULL मानों को अलग तरीके से प्रबंधित करता है। AUTO_INCREMENT कॉलम में प्रविष्टि अनुक्रम में अगले नंबर को इसके स्थान पर डालने का कारण बनती है। TIMESTAMP फ़ील्ड में, MariaDB वर्तमान टाइमस्टैम्प को इसके बजाय असाइन करती है। वर्चुअल कॉलम में, इस ट्यूटोरियल में बाद में चर्चा किए गए विषय, डिफ़ॉल्ट मान असाइन किया गया है।
अद्वितीय संकेत कई NULL मान रख सकते हैं, हालाँकि, प्राथमिक कुंजियाँ NULL नहीं हो सकती हैं।
NULL Values and Alter Command
जब आप किसी स्तंभ को संशोधित करने के लिए ALTER कमांड का उपयोग करते हैं, तो NULL विशिष्टताओं की अनुपस्थिति में, MariaDB स्वचालित रूप से मान प्रदान करता है।