MySQLi - डेटा प्रकार
किसी तालिका में फ़ील्ड्स को ठीक से परिभाषित करना आपके डेटाबेस के समग्र अनुकूलन के लिए महत्वपूर्ण है। आपको केवल फ़ील्ड के प्रकार और आकार का उपयोग करना चाहिए जिसे आपको वास्तव में उपयोग करने की आवश्यकता है; यदि आप जानते हैं कि आप केवल 2 वर्णों का उपयोग करने जा रहे हैं तो किसी फ़ील्ड को 10 वर्णों के रूप में परिभाषित न करें। इस प्रकार के फ़ील्ड (या कॉलम) को डेटा प्रकार के रूप में भी संदर्भित किया जाता है, के बादtype of data आप उन क्षेत्रों में भंडारण करेंगे।
MySQLi तीन श्रेणियों में विभाजित कई अलग-अलग डेटा प्रकारों का उपयोग करता है: संख्यात्मक, दिनांक और समय, और स्ट्रिंग प्रकार।
संख्यात्मक डेटा प्रकार
MySQLi सभी मानक ANSI SQL संख्यात्मक डेटा प्रकारों का उपयोग करता है, इसलिए यदि आप एक अलग डेटाबेस सिस्टम से MySQLi पर आ रहे हैं, तो ये परिभाषाएँ आपको परिचित लगेंगी। निम्न सूची सामान्य संख्यात्मक डेटा प्रकार और उनके विवरण दिखाती है -
INT- एक सामान्य आकार का पूर्णांक जो हस्ताक्षर या अहस्ताक्षरित हो सकता है। यदि हस्ताक्षर किए गए हैं, तो स्वीकार्य सीमा -2147483648 से 2147483647 है। यदि अहस्ताक्षरित है, तो स्वीकार्य सीमा 0 से 4294967295 तक है। आप 11 अंकों की चौड़ाई निर्दिष्ट कर सकते हैं।
TINYINT- एक बहुत छोटा पूर्णांक जो हस्ताक्षरित या अहस्ताक्षरित हो सकता है। यदि हस्ताक्षरित है, तो स्वीकार्य सीमा -128 से 127 है। यदि अहस्ताक्षरित है, तो स्वीकार्य सीमा 0 से 255 तक है। आप 4 अंकों तक की चौड़ाई निर्दिष्ट कर सकते हैं।
SMALLINT- एक छोटा पूर्णांक जो हस्ताक्षर या अहस्ताक्षरित हो सकता है। यदि हस्ताक्षरित है, तो स्वीकार्य सीमा -32768 से 32767 है। यदि अहस्ताक्षरित है, तो स्वीकार्य सीमा 0 से 65535 तक है। आप 5 अंकों तक की चौड़ाई निर्दिष्ट कर सकते हैं।
MEDIUMINT- एक मध्यम आकार का पूर्णांक जो हस्ताक्षरित या अहस्ताक्षरित हो सकता है। यदि हस्ताक्षरित हैं, तो स्वीकार्य सीमा -8388608 से 8388607 है। यदि अहस्ताक्षरित है, तो स्वीकार्य सीमा 0 से 16777215 तक है। आप अधिकतम 9 अंकों की चौड़ाई निर्दिष्ट कर सकते हैं।
BIGINT- एक बड़ा पूर्णांक जो हस्ताक्षरित या अहस्ताक्षरित हो सकता है। यदि हस्ताक्षरित हैं, तो स्वीकार्य सीमा -9223372036854775808 से 9223372036854775807 है। यदि अहस्ताक्षरित है, तो स्वीकार्य सीमा 0 से 18446744073709551615 है। आप अधिकतम 20 अंकों की चौड़ाई निर्दिष्ट कर सकते हैं।
FLOAT(M,D)- एक फ़्लोटिंग-पॉइंट नंबर जो अहस्ताक्षरित नहीं हो सकता है। आप प्रदर्शन लंबाई (एम) और दशमलव (डी) की संख्या को परिभाषित कर सकते हैं। यह आवश्यक नहीं है और 10,2 पर डिफ़ॉल्ट होगा, जहां 2 दशमलव की संख्या है और 10 अंकों की कुल संख्या (दशमलव सहित) है। दशमलव सटीकता एक FLOAT के लिए 24 स्थानों पर जा सकती है।
DOUBLE(M,D)- एक डबल सटीक फ़्लोटिंग-पॉइंट नंबर जो अहस्ताक्षरित नहीं हो सकता है। आप प्रदर्शन लंबाई (एम) और दशमलव (डी) की संख्या को परिभाषित कर सकते हैं। यह आवश्यक नहीं है और यह 16,4 पर डिफ़ॉल्ट होगा, जहां 4 दशमलव की संख्या है। दशमलव सटीकता एक डबेल के लिए 53 स्थानों पर जा सकती है। REAL, DOUBLE का पर्याय है।
DECIMAL(M,D) एक अनपैक फ़्लोटिंग-पॉइंट नंबर जो अहस्ताक्षरित नहीं हो सकता है। अनपैक्ड डेसीमल में, प्रत्येक दशमलव एक बाइट से मेल खाता है। प्रदर्शन लंबाई (एम) और दशमलव (डी) की संख्या को परिभाषित करना आवश्यक है। NUMERIC DECIMAL का पर्याय है।
दिनांक और समय के प्रकार
MySQL की तारीख और समय डेटाटाइप हैं -
DATE- YYYY-MM-DD प्रारूप में एक तिथि, 1000-01-01 और 9999-12-31 के बीच। उदाहरण के लिए, 30 दिसंबर, 1973 को 1973-12-30 के रूप में संग्रहीत किया जाएगा।
DATETIME- YYYY-MM-DD-HH: MM: SS प्रारूप, 1000-01-01 00:00:00 और 9999-12-31 23:59:59 के बीच की तारीख और समय का संयोजन। उदाहरण के लिए, 30 दिसंबर 1973 को दोपहर में 3:30, 1973-12-30 15:30:00 के रूप में संग्रहीत किया जाएगा।
TIMESTAMP - मध्यरात्रि, 1 जनवरी 1970 और 2037 में कुछ समय के बीच का टाइमस्टैम्प। यह पिछले DATETIME प्रारूप जैसा दिखता है, केवल संख्याओं के बीच हाइफ़न के बिना; 30 दिसंबर, 1973 को दोपहर में 3:30 को 19731230153000 (YYYYMMDDHHMMSS) के रूप में संग्रहीत किया जाएगा।
TIME - HH: MM: SS प्रारूप में समय संग्रहीत करता है।
YEAR(M)- 2-अंकीय या 4-अंकीय प्रारूप में एक वर्ष का स्टोर। यदि लंबाई 2 के रूप में निर्दिष्ट की जाती है (उदाहरण के लिए YEAR (2)), YEAR 1970 से 2069 (70 से 69) हो सकता है। यदि लंबाई 4 के रूप में निर्दिष्ट की गई है, तो YEAR 1901 से 2155 हो सकता है। डिफ़ॉल्ट लंबाई 4 है।
स्ट्रिंग प्रकार
हालाँकि संख्यात्मक और दिनांक प्रकार मज़ेदार हैं, लेकिन आपके द्वारा संग्रहित अधिकांश डेटा स्ट्रिंग प्रारूप में होंगे। इस सूची में MySQLi के सामान्य स्ट्रिंग डेटाटिप्स का वर्णन किया गया है।
CHAR(M)- लंबाई में 1 और 255 अक्षरों के बीच एक निश्चित लंबाई की स्ट्रिंग (उदाहरण के लिए CHAR (5)), संग्रहीत होने पर निर्दिष्ट लंबाई के लिए रिक्त स्थान के साथ दाएं-गद्देदार। लंबाई निर्धारित करना आवश्यक नहीं है, लेकिन डिफ़ॉल्ट 1 है।
VARCHAR(M)- लंबाई में 1 और 255 अक्षरों के बीच एक चर-लंबाई स्ट्रिंग; उदाहरण के लिए VARCHAR (25)। VARCHAR फ़ील्ड बनाते समय आपको एक लंबाई निर्धारित करनी चाहिए।
BLOB or TEXT- अधिकतम 65535 वर्णों वाला क्षेत्र। BLOBs "बाइनरी लार्ज ऑब्जेक्ट्स" हैं और इनका उपयोग बाइनरी डेटा की बड़ी मात्रा को स्टोर करने के लिए किया जाता है, जैसे कि चित्र या अन्य प्रकार की फाइलें। TEXT के रूप में परिभाषित फ़ील्ड भी बड़ी मात्रा में डेटा रखती हैं; दोनों के बीच अंतर यह है कि संग्रहीत डेटा पर सॉर्ट और तुलना BLOB पर संवेदनशील हैं और TEXT क्षेत्रों में संवेदनशील नहीं हैं। आप BLOB या TEXT के साथ लंबाई निर्दिष्ट नहीं करते हैं।
TINYBLOB or TINYTEXT- अधिकतम 255 वर्णों वाला एक BLOB या TEXT कॉलम। आप TINYBLOB या TINYTEXT के साथ एक लंबाई निर्दिष्ट नहीं करते हैं।
MEDIUMBLOB or MEDIUMTEXT- 16777215 वर्णों की अधिकतम लंबाई के साथ एक BLOB या पाठ स्तंभ। आप MEDIUMBLOB या MEDIUMTEXT के साथ एक लंबाई निर्दिष्ट नहीं करते हैं।
LONGBLOB or LONGTEXT- अधिकतम 4294967295 वर्णों वाला एक BLOB या TEXT कॉलम। आप LONGBLOB या LONGTEXT के साथ एक लंबाई निर्दिष्ट नहीं करते हैं।
ENUM - एक गणना, जो सूची के लिए एक फैंसी शब्द है। एक ENUM को परिभाषित करते समय, आप उन वस्तुओं की एक सूची बना रहे हैं, जिनसे मूल्य का चयन किया जाना चाहिए (या यह पूर्ण हो सकता है)। उदाहरण के लिए, यदि आप चाहते थे कि आपका क्षेत्र "A" या "B" या "C" सम्मिलित करे, तो आप अपने ENUM को ENUM ('A', 'B', 'C') और केवल उन मानों (या NULL) के रूप में परिभाषित करेंगे। कभी भी उस क्षेत्र को आबाद कर सकता है।