1. परिचय
MySQL एक लोकप्रिय संबंधित डेटाबेस प्रबंधन प्रणाली है जो कई वेब अनुप्रयोगों और डेटाबेस सिस्टम में व्यापक रूप से उपयोग की जाती है। इसके डेटा प्रकारों में से, INT प्रकार संख्यात्मक मानों को संभालने के लिए सबसे अधिक उपयोग किया जाने वाला प्रकारों में से एक है। यह लेख MySQL INT प्रकार की विस्तृत व्याख्या प्रदान करता है। विशेष रूप से, हम INT प्रकार द्वारा समर्थित अधिकतम मानों का अन्वेषण करेंगे और इसे कुशलतापूर्वक उपयोग करने के तरीके को जानेंगे। इस लेख को पढ़कर, आपको MySQL में INT प्रकार का उचित उपयोग करने के लिए आवश्यक ज्ञान प्राप्त हो जाएगा।
2. INT प्रकार की मूल विशेषताएँ
INT के अधिकतम और न्यूनतम मान
MySQL INT प्रकार 4 बाइट्स (32 बिट्स) का भंडारण उपयोग करता है, और यह स्टोर कर सकने वाले मानों की सीमा निम्नलिखित है:
- साइन वाले (SIGNED) :
- न्यूनतम मान: -2,147,483,648
- अधिकतम मान: 2,147,483,647
- बिना साइन वाले (UNSIGNED) :
- न्यूनतम मान: 0
- अधिकतम मान: 4,294,967,295
INT का भंडारण आकार
INT प्रकार हमेशा 4 बाइट्स का भंडारण उपयोग करता है। यह आकार स्टोर किए गए मान की परवाह किए बिना स्थिर रहता है। इसलिए, यदि आपको बहुत बड़े संख्यात्मक सीमा को संभालने की आवश्यकता नहीं है, तो छोटे डेटा प्रकारों (उदाहरण के लिए, TINYINT या SMALLINT) पर विचार करना अधिक कुशल है।
INT के उपयोग के मामले
INT प्रकार निम्नलिखित परिदृश्यों में सामान्य रूप से उपयोग किया जाता है:
- स्वतः-वृद्धि मान (जैसे, उपयोगकर्ता आईडी, ऑर्डर नंबर)
- गणनाओं या सांख्यिकीय प्रसंस्करण में उपयोग किए जाने वाले पूर्णांक डेटा (जैसे, इन्वेंटरी गणना, क्लिक गणना)
- निश्चित सीमा के अंदर प्रतिनिधित्व किए गए डेटा (जैसे, आयु या परीक्षा स्कोर)
इन उपयोग के मामलों में, आवश्यक संख्यात्मक सीमा और मेमोरी दक्षता पर विचार करना महत्वपूर्ण है।
3. INT(M) में M का क्या अर्थ है?
प्रदर्शन चौड़ाई (M) क्या है?
MySQL में, INT(M) में M “प्रदर्शन चौड़ाई” का प्रतिनिधित्व करता है। यह डेटाबेस में स्टोर किए गए वास्तविक संख्यात्मक मान को प्रभावित नहीं करता; इसके बजाय, यह निर्दिष्ट करता है कि मान प्रदर्शित होने पर कैसे फॉर्मेट किया जाता है। उदाहरण के लिए, यदि INT(5) के रूप में परिभाषित किया गया है, तो संख्या 5 अंकों की चौड़ाई के साथ प्रदर्शित होगी।
हालांकि, प्रदर्शन चौड़ाई M का अर्थ केवल निम्नलिखित मामले में है:
- जब ZEROFILL विकल्प सक्षम हो
- उदाहरण:
INT(5) ZEROFILLके साथ, यदि मान123है, तो यह00123के रूप में प्रदर्शित होगा।
ZEROFILL के बारे में महत्वपूर्ण नोट्स
ZEROFILL विकल्प का उपयोग करते समय, निम्नलिखित विशेषताएँ लागू होती हैं:
- बाएँ ओर अग्रणी शून्य स्वचालित रूप से जोड़े जाते हैं।
UNSIGNEDविशेषता स्वचालित रूप से लागू की जाती है।
इसलिए, यदि आपको ऋणात्मक मानों को स्टोर करने की आवश्यकता है, तो आप ZEROFILL का उपयोग नहीं कर सकते।
सामान्य गलतफहमियों को स्पष्ट करना
कई शुरुआती गलती से मानते हैं कि M अधिकतम स्टोर करने योग्य मान को सीमित करता है। हालांकि, M केवल प्रदर्शन फॉर्मेटिंग को प्रभावित करता है और वास्तविक भंडारण सीमा पर बिल्कुल कोई प्रभाव नहीं डालता।
4. अन्य पूर्णांक प्रकारों के साथ तुलना
पूर्णांक डेटा प्रकारों के प्रकार और उनकी सीमाएँ
MySQL निम्नलिखित पूर्णांक प्रकार प्रदान करता है:
| Type Name | Bytes | Signed Range | Unsigned Range |
|---|---|---|---|
| TINYINT | 1 byte | -128 to 127 | 0 to 255 |
| SMALLINT | 2 bytes | -32,768 to 32,767 | 0 to 65,535 |
| MEDIUMINT | 3 bytes | -8,388,608 to 8,388,607 | 0 to 16,777,215 |
| INT | 4 bytes | -2,147,483,648 to 2,147,483,647 | 0 to 4,294,967,295 |
| BIGINT | 8 bytes | -9,223,372,036,854,775,808 to 9,223,372,036,854,775,807 | 0 to 18,446,744,073,709,551,615 |
चयन मानदंड
डेटाबेस डिज़ाइन में उपयुक्त डेटा प्रकार का चयन करते समय निम्नलिखित दिशानिर्देशों का उपयोग करें:
- यदि सीमा छोटी है: मेमोरी बचाने के लिए
TINYINTयाSMALLINTका उपयोग करें। - यदि अत्यंत बड़ी सीमा की आवश्यकता है:
BIGINTका उपयोग करें। - यदि सामान्य-उद्देश्य उपयोग की इच्छा है:
INTआमतौर पर इष्टतम होता है।
5. MySQL 8.0.17 के बाद के परिवर्तन
प्रदर्शन चौड़ाई (M) का अवमूल्यन
MySQL 8.0.17 से शुरू, पूर्णांक प्रकारों के लिए “प्रदर्शन चौड़ाई (M)” का अवमूल्यन किया गया है। यह परिवर्तन ZEROFILL विकल्प के अवमूल्यन के साथ पेश किया गया था, और यह भविष्य के MySQL संस्करणों में हटा दिया जा सकता है।
प्रदर्शन चौड़ाई के अवमूल्यन के कारण निम्नलिखित हैं:
- गलतफहमियाँ पैदा की:
- कई उपयोगकर्ताओं ने गलती से समझा कि
Mअधिकतम स्टोर करने योग्य मान या अंकों की संख्या को प्रभावित करता है।
- सीमित व्यावहारिक उपयोग:
- चूंकि
Mकेवल प्रदर्शन फॉर्मेटिंग को नियंत्रित करता था, अब फॉर्मेटिंग सामान्यतः एप्लिकेशन पक्ष पर संभाली जाती है, जिससे इसकी आवश्यकता कम हो गई है।
ZEROFILL का अवमूल्यन
The ZEROFILL विकल्प को भी उसी संस्करण में अप्रचलित कर दिया गया था। जबकि ZEROFILL अग्रणी शून्य के साथ संख्याओं को पैड करने में सुविधाजनक था, अब इसे निम्नलिखित कारणों से अनुशंसित नहीं किया जाता है:
- व्यापक वैकल्पिक दृष्टिकोण:
- अब शून्य‑पैडिंग को आसानी से एप्लिकेशन या UI लेयर में संभाला जा सकता है।
- भ्रम से बचना:
ZEROFILLका उपयोग करते समयUNSIGNEDविशेषता का स्वचालित लागू होना शुरुआती उपयोगकर्ताओं के लिए भ्रम पैदा करता था।
How to Adapt to the Deprecation
इन अप्रचलनों के जवाब में, डेटाबेस डिज़ाइन में निम्नलिखित दृष्टिकोणों पर विचार करें:
- एप्लिकेशन लेयर में फ़ॉर्मेटिंग संभालें:
- एप्लिकेशन या प्रस्तुति लेयर में शून्य‑पैडिंग और फ़ॉर्मेटिंग करें।
- उदाहरण: PHP या JavaScript का उपयोग करके शून्य‑पैडिंग लागू करें।
- ऐसा डिज़ाइन अपनाएँ जो डिस्प्ले चौड़ाई पर निर्भर न हो:
Mनिर्दिष्ट किए बिनाINTप्रकार को परिभाषित करें और डिस्प्ले फ़ॉर्मेटिंग के बजाय डेटा की शुद्धता पर ध्यान दें।
6. Practical FAQ Section
Frequently Asked Questions
Q1. What happens if I store a value exceeding the maximum of the INT type?
A. MySQL में, INT प्रकार की सीमा से बाहर का मान संग्रहीत करने का प्रयास करने पर त्रुटि उत्पन्न होगी। आपको या तो समर्थित सीमा के भीतर मान चुनना होगा या बड़े रेंज वाले डेटा प्रकार (उदाहरण के लिए, BIGINT) पर स्विच करना होगा।
Q2. What is the difference between INT and BIGINT?
A. BIGINT प्रकार INT (8 बाइट) की तुलना में दो गुना स्टोरेज उपयोग करता है और बहुत विस्तृत संख्यात्मक रेंज प्रदान करता है। उदाहरण के लिए, BIGINT की साइन की गई रेंज ±9 क्विंटिलियन से अधिक होती है, जिससे यह बहुत बड़े डेटा सेट को संभालने के लिए उपयुक्त बनता है।
Q3. After ZEROFILL is deprecated, how should I implement zero-padded display?
A. शून्य‑पैडिंग को एप्लिकेशन लेयर में संभालने की सलाह दी जाती है। उदाहरण के लिए, PHP में आप str_pad() फ़ंक्शन का उपयोग कर सकते हैं, और JavaScript में padStart() मेथड का उपयोग करके शून्य‑पैडिंग लागू कर सकते हैं।
Q4. How should I choose between INT and other integer types?
A. डेटा रेंज के आधार पर प्रकार चुनें। छोटे संख्यात्मक मान (जैसे आयु या स्कोर) के लिए TINYINT उपयुक्त है, मध्यम‑स्तर के डेटा (जैसे उपयोगकर्ता आईडी) के लिए INT उपयुक्त है, और बहुत बड़े मान (जैसे वित्तीय लेन‑देन डेटा) के लिए BIGINT उपयुक्त है।
7. Conclusion
इस लेख में, हमने MySQL INT डेटा प्रकार की विस्तृत व्याख्या प्रदान की है। मुख्य बिंदु इस प्रकार हैं:
INTप्रकार के साइन और अनसाइन अधिकतम तथा न्यूनतम मानों के बीच अंतर को समझना उचित डेटा डिज़ाइन की नींव बनाता है।- अप्रचलित “डिस्प्ले चौड़ाई (M)” और “ZEROFILL” विकल्पों के वैकल्पिक दृष्टिकोणों को समझना और भविष्य के MySQL अपडेट के अनुकूल डेटाबेस डिज़ाइन करना महत्वपूर्ण है।
- डेटा की विशेषताओं के आधार पर उपयुक्त पूर्णांक प्रकार चुनें ताकि एक कुशल और रखरखाव योग्य डेटाबेस बनाया जा सके।
इस लेख को संदर्भ के रूप में उपयोग करके INT प्रकार के उपयोग को अनुकूलित करें और MySQL डेटाबेस डिज़ाइन में दक्षता को और अधिक बढ़ाएँ।


