जैसा कि हम जानते हैं कि MySQL संदर्भात्मक अखंडता के लिए विदेशी कुंजी का समर्थन करता है लेकिन यह CHECK बाधा का समर्थन नहीं करता है। लेकिन हम ट्रिगर्स का उपयोग करके उनका अनुकरण कर सकते हैं। इसे नीचे दिए गए उदाहरण की मदद से स्पष्ट किया जा सकता है -
उदाहरण
मान लीजिए हमारे पास 'कार' नाम की एक टेबल है जिसमें फिक्स सिंटैक्स रजिस्ट्रेशन नंबर हो सकता है जैसे दो अक्षर, एक डैश, तीन अंक, एक डैश, दो अक्षर इस प्रकार हैं -
mysql> Create table car2 (number char(9)); Query OK, 0 rows affected (0.32 sec) mysql> Insert into car2 values('AB-235-YZ'); Query OK, 1 row affected (0.10 sec)
उपरोक्त मान मान्य है लेकिन उस मूल्य के बारे में क्या है जिसे हम अगली क्वेरी में सम्मिलित करने जा रहे हैं।
mysql> insert into car2 values('AB-2X5-YZ'); Query OK, 1 row affected (0.04 sec)
उपरोक्त मान मान्य नहीं है क्योंकि इसमें अंकों के बीच एक वर्ण होता है जो हमारे द्वारा उपयोग किए जा रहे निश्चित सिंटैक्स के विरुद्ध होता है।
मानों को डालने और अपडेट करने के लिए CHECK CONSTRAINT का अनुकरण करने के लिए जेनरेटेड कॉलम का उपयोग करना -
mysql> Alter table car2 add column number_validate char(0) as (case when number rlike '^[[:alpha:]]{2}-[[:digit:]]{3}-[[:alpha:]]{2}$' -> then '' end) -> virtual not null; Query OK, 0 rows affected (0.53 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql> Describe car2; +-----------------+---------+------+-----+---------+-------------------+ | Field | Type | Null | Key | Default | Extra | +-----------------+---------+------+-----+---------+-------------------+ | number | char(9) | YES | | NULL | | | number_validate | char(0) | NO | | NULL | VIRTUAL GENERATED | +-----------------+---------+------+-----+---------+-------------------+ 2 rows in set (0.00 sec) mysql> Insert into car2 (number) values('AB-235-YZ'); Query OK, 1 row affected (0.09 sec)
उपरोक्त क्वेरी मान्य संख्या सम्मिलित करती है इसलिए इसे स्वीकार किया जाता है। लेकिन नीचे दी गई क्वेरी मान्य संख्या को डालने के साथ-साथ अपडेट नहीं कर रही है।
mysql> Insert into car2 (number) values('AB-2X5-YZ'); ERROR 1048 (23000): Column 'number_validate' cannot be null mysql> Update car2 set number='AB-2X5-YZ'; ERROR 1048 (23000): Column 'number_validate' cannot be null