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

SQL सर्वर ANSI_NULLS समझाया गया

SQL सर्वर में, ANSI_NULLS सेटिंग आपको यह निर्दिष्ट करने की अनुमति देती है कि कैसे NULL प्रश्नों में मूल्यों का इलाज किया जाता है।

अधिक विशेष रूप से, यह आपको बराबर के आईएसओ अनुरूप व्यवहार को निर्दिष्ट करने की अनुमति देता है (= ) और इसके बराबर नहीं (<> ) तुलना ऑपरेटर जब उनका उपयोग NULL . के साथ किया जाता है मान।

ANSI_NULLS ON पर सेट किया जा सकता है या OFF . एक NULL परीक्षण जो ANSI_NULLS OFF . के साथ सत्य लौटाता है ANSI_NULLS ON with के साथ वास्तव में झूठी वापसी कर सकता है ।

यह बहुत भ्रम का स्रोत हो सकता है, और इसलिए यह समझने के लिए भुगतान करता है कि कैसे ANSI_NULLS काम करता है।

ANSI_NULLS सेटिंग्स को डेटाबेस स्तर और सत्र स्तर पर सेट किया जा सकता है। यदि कोई ANSI_NULLS सत्र स्तर पर सेटिंग निर्दिष्ट नहीं है, SQL सर्वर जो भी ANSI_NULLS का उपयोग करेगा सेटिंग वर्तमान डेटाबेस पर लागू होती है। इसलिए, तदर्थ प्रश्न लिखते समय आप अपनी स्वयं की सत्र स्तर सेटिंग के साथ डेटाबेस सेटिंग को ओवरराइड कर सकते हैं।

ध्यान देने योग्य एक महत्वपूर्ण बात यह है कि SQL सर्वर नेटिव क्लाइंट ODBC ड्राइवर और SQL सर्वर के लिए SQL सर्वर नेटिव क्लाइंट OLE DB प्रदाता स्वचालित रूप से ANSI_NULLS सेट करता है। करने के लिए ON कनेक्ट करते समय। इस सेटिंग को ODBC डेटा स्रोतों में, ODBC कनेक्शन विशेषताओं में, या OLE DB कनेक्शन गुणों में कॉन्फ़िगर किया जा सकता है जो SQL सर्वर की आवृत्ति से कनेक्ट होने से पहले एप्लिकेशन में सेट हैं।

अपने सत्र की ANSI_NULLS सेटिंग की जांच कैसे करें

आप SESSIONPROPERTY() . का उपयोग कर सकते हैं ANSI_NULLS . की जांच करने के लिए कार्य करें वर्तमान सत्र के लिए सेटिंग।

SELECT SESSIONPROPERTY('ANSI_NULLS');

परिणाम:

+--------------------+
| (No column name)   |
|--------------------|
| 1                  |
+--------------------+

इस मामले में, ANSI_NULLS मेरे सत्र के लिए सेटिंग ON है .

एक शून्य (0 ) का मतलब होगा कि यह बंद है।

अपने सत्र की ANSI_NULLS सेटिंग कैसे बदलें

आप अपने सत्र की ANSI_NULLS सेटिंग को OFF . पर सेट कर सकते हैं निम्नलिखित कोड के साथ:

SET ANSI_NULLS OFF;

फिर इसे फिर से जाँचने पर एक शून्य उत्पन्न होगा।

SELECT SESSIONPROPERTY('ANSI_NULLS');

परिणाम:

+--------------------+
| (No column name)   |
|--------------------|
| 0                  |
+--------------------+

SET ANSI_NULLS . के लिए डिफ़ॉल्ट मान OFF है . हालाँकि, जैसा कि ऊपर बताया गया है, SQL सर्वर नेटिव क्लाइंट ODBC ड्राइवर और SQL सर्वर के लिए SQL सर्वर नेटिव क्लाइंट OLE DB प्रदाता स्वचालित रूप से ANSI_NULLS सेट करता है। करने के लिए ON कनेक्ट करते समय।

कैसे के उदाहरण ANSI_NULLS क्वेरी को प्रभावित करता है

ANSI_NULLS के मान के आधार पर आपको मिलने वाले विभिन्न परिणामों को प्रदर्शित करने के लिए यहां कुछ बुनियादी उदाहरण दिए गए हैं सेटिंग।

ये SET ANSI_NULLS . का उपयोग करते हैं ANSI_NULLS को टॉगल करने के लिए वर्तमान सत्र के लिए सेटिंग।

ANSI_NULLS ON

SET ANSI_NULLS ON;

SELECT NULL
WHERE NULL = NULL;

परिणाम:

(0 rows affected)

जब ANSI_NULLS ON है , एक NULL . के विरुद्ध सभी तुलनाएं मान UNKNOWN का मूल्यांकन करें .

इस मामले में, हम यह नहीं कह सकते कि NULL बराबर NULL क्योंकि प्रत्येक मान अज्ञात है।

इसलिए, उपरोक्त क्वेरी के लिए कोई पंक्तियाँ नहीं लौटाई गई हैं।

ANSI_NULLS OFF

SET ANSI_NULLS OFF;

SELECT NULL
WHERE NULL = NULL;

परिणाम:

+--------------------+
| (No column name)   |
|--------------------|
| NULL               |
+--------------------+

जब ANSI_NULLS OFF है , सभी डेटा की तुलना NULL . से करना मान TRUE . का मूल्यांकन करें यदि डेटा मान NULL है ।

नॉट इक्वल टू ऑपरेटर का उपयोग करते समय भी यही तर्क लागू होता है (<> )।

आइए नॉट इक्वल टू ऑपरेटर को शामिल करने के लिए उदाहरण का विस्तार करें (<> ), साथ ही NULL . के बीच तुलना और एक गैर-NULL मूल्य।

ANSI_NULLS ON

SET ANSI_NULLS ON;

SELECT NULL
WHERE NULL = NULL;

SELECT 'Not NULL'
WHERE NULL <> NULL;

SELECT NULL
WHERE 1 = NULL;

SELECT 'Not NULL'
WHERE 1 <> NULL;

परिणाम:

(0 rows affected)
(0 rows affected)
(0 rows affected)
(0 rows affected)

जैसा कि अपेक्षित था, किसी भी प्रश्न के लिए कोई पंक्तियाँ नहीं लौटाई गई हैं। ऐसा इसलिए है क्योंकि NULL मानों को UNKNOWN के रूप में माना जाता है मान जब ANSI_NULLS ON है .

ANSI_NULLS OFF

SET ANSI_NULLS OFF;

SELECT NULL
WHERE NULL = NULL;

SELECT 'Not NULL'
WHERE NULL <> NULL;

SELECT NULL
WHERE 1 = NULL;

SELECT 'Not NULL'
WHERE 1 <> NULL;

परिणाम:

+--------------------+
| (No column name)   |
|--------------------|
| NULL               |
+--------------------+
(1 row affected)
(0 rows affected)
(0 rows affected)
+--------------------+
| (No column name)   |
|--------------------|
| Not NULL           |
+--------------------+
(1 row affected)

ANSI_NULLS . पर हमें एक अलग परिणाम मिलता है OFF है .

इस मामले में, SQL सर्वर NULL का इलाज नहीं करता है UNKNOWN . के रूप में . यह निर्धारित करता है कि NULL वास्तव में NULL . के बराबर है ।

यह एएनएसआई मानक के अनुरूप नहीं है।

IS NULL विधेय

ANSI_NULLS . पर ध्यान दिए बिना किसी स्क्रिप्ट के इरादे के अनुसार काम करने के लिए डेटाबेस विकल्प या SET ANSI_NULLS . की सेटिंग , IS NULL . का उपयोग करें और IS NOT NULL उन तुलनाओं में जिनमें शून्य मान हो सकते हैं

यहाँ क्या होता है जब हम IS NULL . का उपयोग करने के लिए पिछले उदाहरण को फिर से लिखते हैं और IS NOT NULL

ANSI_NULLS ON

SET ANSI_NULLS ON;

SELECT NULL
WHERE NULL IS NULL;

SELECT NULL
WHERE NULL IS NOT NULL;

SELECT 'Not NULL'
WHERE 1 IS NULL;

SELECT 'Not NULL'
WHERE 1 IS NOT NULL;

परिणाम:

+--------------------+
| (No column name)   |
|--------------------|
| NULL               |
+--------------------+
(1 row affected)
(0 rows affected)
(0 rows affected)
+--------------------+
| (No column name)   |
|--------------------|
| Not NULL           |
+--------------------+
(1 row affected)

ANSI_NULLS OFF

SET ANSI_NULLS OFF;

SELECT NULL
WHERE NULL IS NULL;

SELECT NULL
WHERE NULL IS NOT NULL;

SELECT 'Not NULL'
WHERE 1 IS NULL;

SELECT 'Not NULL'
WHERE 1 IS NOT NULL;

परिणाम:

+--------------------+
| (No column name)   |
|--------------------|
| NULL               |
+--------------------+
(1 row affected)
(0 rows affected)
(0 rows affected)
+--------------------+
| (No column name)   |
|--------------------|
| Not NULL           |
+--------------------+
(1 row affected)

जैसा अपेक्षित था, हमें ANSI_NULLS . की परवाह किए बिना वही परिणाम मिलता है सेटिंग।

तुलना तालिका

निम्न तालिका बूलियन व्यंजक और ANSI_NULLS के आधार पर आपके द्वारा प्राप्त की जा सकने वाली विविधताओं को रेखांकित करती है सेटिंग।

बूलियन एक्सप्रेशन ANSI_NULLS चालू करें ANSI_NULLS बंद सेट करें
NULL =NULL अज्ञात सच
1 =NULL अज्ञात गलत
नल <> NULL अज्ञात गलत
1 <> NULL अज्ञात सच
नल> NULL अज्ञात अज्ञात
1> NULL अज्ञात अज्ञात
शून्य शून्य है सच सच
1 IS NULL गलत गलत
नल न्यूल नहीं है गलत गलत
1 खाली नहीं है सच सच

डेटाबेस स्तर पर ANSI_NULLS सेट करना

प्रत्येक SQL सर्वर डेटाबेस में एक ANSI_NULLS होता है सेटिंग, जो निर्धारित करती है कि NULL . से तुलना कैसे की जाती है मूल्यों का मूल्यांकन किया जाता है।

  • जब ON पर सेट किया जाता है , एक NULL . से तुलना मान UNKNOWN का मूल्यांकन करें ।
  • जब OFF पर सेट किया जाता है , गैर-यूनिकोड मानों की तुलना NULL . से करना मान TRUE . का मूल्यांकन करें यदि दोनों मान NULL हैं ।

आप निम्न कोड वाले डेटाबेस पर इस सेटिंग को बदल सकते हैं:

ALTER DATABASE CURRENT
SET ANSI_NULLS ON;

यह ANSI_NULLS sets सेट करता है करने के लिए ON वर्तमान डेटाबेस के लिए। आप CURRENT स्वैप कर सकते हैं यदि पसंद हो तो डेटाबेस के नाम के साथ।

आप DATABASEPROPERTYEX() . के साथ वर्तमान सेटिंग की जांच कर सकते हैं समारोह।

SELECT DATABASEPROPERTYEX('Music','IsAnsiNullsEnabled');

परिणाम:

1

जैसा कि उल्लेख किया गया है, आप इस सेटिंग को सत्र स्तर पर सेट करके तदर्थ प्रश्न लिखते समय ओवरराइड कर सकते हैं जैसे हमने पहले किया था।

जब हम इस विषय पर होते हैं, तो मुझे यह उल्लेख करना चाहिए कि SQL सर्वर डेटाबेस में एक ANSI_NULL_DEFAULT भी होता है। सेटिंग। यह सेटिंग डिफ़ॉल्ट मान निर्धारित करती है, NULL या NOT NULL , एक स्तंभ या CLR उपयोगकर्ता-परिभाषित प्रकार का, जिसके लिए CREATE TABLE में स्पष्ट रूप से शून्यता को परिभाषित नहीं किया गया है या ALTER TABLE बयान।

यह मान इस तरह सेट किया जा सकता है:

ALTER DATABASE CURRENT
SET ANSI_NULL_DEFAULT ON;

इसका मान इस प्रकार प्राप्त किया जा सकता है:

SELECT DATABASEPROPERTYEX('Music','IsAnsiNullDefault');

परिणाम:

1

आप sys.databases . का भी उपयोग कर सकते हैं सभी डेटाबेस के लिए इन सेटिंग्स को वापस करने के लिए कैटलॉग व्यू।

SELECT
    name,
    is_ansi_nulls_on,
    is_ansi_null_default_on
FROM sys.databases
ORDER BY name ASC;


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. लिनक्स पर SQL सर्वर कैसे स्थापित करें

  2. SQL सर्वर में बल्क इंसर्ट का उपयोग करके UTF-8 वर्ण कैसे लिखें?

  3. COS () SQL सर्वर में उदाहरण

  4. SQL सर्वर 2005 में एक कथन में दो तालिकाओं को कैसे अपडेट करें?

  5. लॉग के बिना SQL में तालिका के बड़े डेटा को कैसे हटाएं?