MySQL ENUM प्रकारों को निम्नलिखित विशेषताओं के साथ परिभाषित किया जा सकता है जो अनुमत मानों को प्रभावित करते हैं -
- पूर्ण नहीं - ENUM प्रकार में, डिफ़ॉल्ट रूप से NULL मानों की अनुमति है। NULL मानों को अस्वीकार करने के लिए, हमें ENUM कॉलम का वर्णन करते समय NOT NULL विशेषता का उपयोग करने की आवश्यकता है।
- शून्य - NULL विशेषता DEFAULT NULL का पर्याय है। NULL के लिए अनुक्रमणिका मान NULL है।
- डिफ़ॉल्ट - जब कोई मान निर्दिष्ट नहीं होता है, तो DEFAULT विशेषता एक ENUM डेटा प्रकार के लिए एक डिफ़ॉल्ट मान का कारण बनती है। दूसरे शब्दों में, हम कह सकते हैं कि INSERT स्टेटमेंट में इस फ़ील्ड के लिए कोई मान शामिल करने की आवश्यकता नहीं है क्योंकि यदि इसमें शामिल नहीं है तो DEFAULT के बाद का मान डाला जाएगा। डिफ़ॉल्ट अभिव्यक्ति में कार्यों की अनुमति नहीं है। ENUM डेटा प्रकार के लिए डिफ़ॉल्ट मानों में NULL और खाली स्ट्रिंग ('') शामिल हैं।
उदाहरण
निम्नलिखित उदाहरण ENUM डेटा प्रकार के साथ इन विशेषताओं के उपयोग को दिखाएगा।
mysql> SET SESSION sql_mode = ''; Query OK, 0 rows affected (0.00 sec) mysql> Create Table enumtesting(e_value ENUM('a','1')NOT NULL DEFAULT '1',id TINYINT NOT NULL); Query OK, 0 rows affected (0.23 sec) mysql>Insert into enumtesting(e_value,id)values('1','1'),('',2),(NULL,3),('abc',4); Query OK, 4 rows affected, 3 warnings (0.09 sec) Records: 4 Duplicates: 0 Warnings: 3 mysql> show warnings; +---------+------+----------------------------------------------------+ | Level | Code | Message | +---------+------+----------------------------------------------------+ | Warning | 1265 | Data truncated for column 'e_value' at row 2 | | Warning | 1048 | Column 'e_value' cannot be null | | Warning | 1265 | Data truncated for column 'e_value' at row 4 | +---------+------+----------------------------------------------------+ 3 rows in set (0.00 sec) mysql> Select * from enumtesting; +----+---------+ | e_value | id | +---------+----+ | 1 | 1 | | | 2 | | | 3 | | | 4 | +---------+----+ 4 rows in set (0.00 sec) mysql> insert into enumtesting(id) values(5); Query OK, 1 row affected (0.11 sec) mysql> Select * from enumtesting; +---------+----+ | e_value | id | +---------+----+ | 1 | 1 | | | 2 | | | 3 | | | 4 | | 1 | 5 | +---------+----+ 5 rows in set (0.00 sec) mysql> select e_value, e_value+0 AS enum_index, id from enumtetsing; +---------+------------+----+ | e_value | enum_index | id | +---------+------------+----+ | 1 | 2 | 1| | | 0 | 2| | | 0 | 3| | | 0 | 4| | 1 | 2 | 5| +---------+------------+----+ 5 rows in set (0.00 sec)