MySQL - ALTER कमांड

MySQL ALTER जब आप अपनी तालिका का नाम बदलना चाहते हैं, तो कोई तालिका फ़ील्ड या यदि आप किसी तालिका में मौजूदा स्तंभ जोड़ना या हटाना चाहते हैं तो कमांड बहुत उपयोगी है।

हमें एक तालिका के निर्माण के साथ शुरू करना चाहिए testalter_tbl

root@host# mysql -u root -p password;
Enter password:*******

mysql> use TUTORIALS;
Database changed

mysql> create table testalter_tbl
   -> (
   -> i INT,
   -> c CHAR(1)
   -> );
Query OK, 0 rows affected (0.05 sec)
mysql> SHOW COLUMNS FROM testalter_tbl;
+-------+---------+------+-----+---------+-------+
| Field |  Type   | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
|   i   | int(11) | YES  |     |   NULL  |       |
|   c   | char(1) | YES  |     |   NULL  |       |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.00 sec)

एक स्तंभ को जोड़ना, जोड़ना या पुनरावृत्ति करना

यदि आप किसी मौजूदा कॉलम i को उपरोक्त MySQL टेबल से छोड़ना चाहते हैं, तो आप इसका उपयोग करेंगे DROP साथ खंड ALTER नीचे दिखाए अनुसार कमांड -

mysql> ALTER TABLE testalter_tbl  DROP i;

DROP यदि तालिका तालिका में केवल एक स्तंभ है, तो क्लॉज काम नहीं करेगा।

स्तंभ जोड़ने के लिए, ADD का उपयोग करें और स्तंभ परिभाषा निर्दिष्ट करें। निम्न कथन पुनर्स्थापित करता हैi testalter_tbl को कॉलम -

mysql> ALTER TABLE testalter_tbl ADD i INT;

इस कथन को जारी करने के बाद, वृषण में वही दो कॉलम होंगे जो उस समय थे जब आपने पहली बार तालिका बनाई थी, लेकिन समान संरचना नहीं होगी। ऐसा इसलिए है क्योंकि नए कॉलम हैं जो डिफ़ॉल्ट रूप से तालिका के अंत में जोड़े जाते हैं। तो इसके बावजूदi मूल रूप से mytbl में पहला कॉलम था, अब यह आखिरी है।

mysql> SHOW COLUMNS FROM testalter_tbl;
+-------+---------+------+-----+---------+-------+
| Field |  Type   | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
|   c   | char(1) | YES  |     |   NULL  |       |
|   i   | int(11) | YES  |     |   NULL  |       |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.00 sec)

यह इंगित करने के लिए कि आप तालिका के भीतर एक विशिष्ट स्थान पर एक स्तंभ चाहते हैं, या तो इसे पहला स्तंभ बनाने के लिए या पहले FIRST का उपयोग करें AFTER col_name यह इंगित करने के लिए कि नया कॉलम col_name के बाद रखा जाना चाहिए।

निम्नलिखित का प्रयास करें ALTER TABLE बयान, का उपयोग कर SHOW COLUMNS हर एक को देखने के बाद कि प्रत्येक का क्या प्रभाव पड़ता है -

ALTER TABLE testalter_tbl DROP i;
ALTER TABLE testalter_tbl ADD i INT FIRST;
ALTER TABLE testalter_tbl DROP i;
ALTER TABLE testalter_tbl ADD i INT AFTER c;

FIRST और AFTER निर्दिष्टकर्ता केवल ADD क्लॉज के साथ काम करते हैं। इसका मतलब यह है कि यदि आप किसी मौजूदा कॉलम को किसी तालिका में रखना चाहते हैं, तो आपको पहले यह करना होगाDROP यह और फिर ADD नई स्थिति में यह।

परिवर्तन (बदलना) एक स्तंभ परिभाषा या एक नाम

कॉलम की परिभाषा बदलने के लिए, का उपयोग करें MODIFY या CHANGE ALTER कमांड के साथ क्लॉज।

उदाहरण के लिए, कॉलम बदलने के लिए c CHAR (1) से CHAR (10) तक, आप निम्नलिखित कमांड का उपयोग कर सकते हैं -

mysql> ALTER TABLE testalter_tbl MODIFY c CHAR(10);

साथ में CHANGE, वाक्यविन्यास थोड़ा अलग है। CHANGE कीवर्ड के बाद, आप उस कॉलम को नाम देते हैं जिसे आप बदलना चाहते हैं, फिर नई परिभाषा निर्दिष्ट करें, जिसमें नया नाम शामिल है।

निम्नलिखित उदाहरण देखें -

mysql> ALTER TABLE testalter_tbl CHANGE i j BIGINT;

यदि आप अब कन्वर्ट करने के लिए CHANGE का उपयोग करते हैं j से BIGINT वापस INT कॉलम का नाम बदले बिना, विवरण नीचे दिखाया जाएगा -

mysql> ALTER TABLE testalter_tbl CHANGE j j INT;

The Effect of ALTER TABLE on Null and Default Value Attributes- जब आप किसी कॉलम को मोडिफाई या चेंज करते हैं, तो आप यह भी निर्दिष्ट कर सकते हैं कि कॉलम में NULL मान हो सकते हैं या नहीं और इसका डिफ़ॉल्ट मान क्या है। वास्तव में, यदि आप ऐसा नहीं करते हैं, तो MySQL स्वचालित रूप से इन विशेषताओं के लिए मान प्रदान करता है।

निम्नलिखित कोड ब्लॉक एक उदाहरण है, जहां NOT NULL कॉलम में डिफ़ॉल्ट रूप से मान 100 होगा।

mysql> ALTER TABLE testalter_tbl 
   -> MODIFY j BIGINT NOT NULL DEFAULT 100;

यदि आप उपरोक्त कमांड का उपयोग नहीं करते हैं, तो MySQL सभी कॉलम में NULL मान भर देगा।

एक स्तंभ के डिफ़ॉल्ट मान को बदलना (बदलना)

आप किसी भी कॉलम के लिए डिफ़ॉल्ट मान को बदलकर उपयोग कर सकते हैं ALTER आदेश।

निम्नलिखित उदाहरण देखें।

mysql> ALTER TABLE testalter_tbl ALTER i SET DEFAULT 1000;
mysql> SHOW COLUMNS FROM testalter_tbl;
+-------+---------+------+-----+---------+-------+
| Field |  Type   | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
|   c   | char(1) | YES  |     |   NULL  |       |
|   i   | int(11) | YES  |     |   1000  |       |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.00 sec)

आप DROP क्लॉज का उपयोग करके किसी भी कॉलम से डिफ़ॉल्ट बाधा को हटा सकते हैं ALTER आदेश।

mysql> ALTER TABLE testalter_tbl ALTER i DROP DEFAULT;
mysql> SHOW COLUMNS FROM testalter_tbl;
+-------+---------+------+-----+---------+-------+
| Field |  Type   | Null | Key | Default | Extra |
+-------+---------+------+-----+---------+-------+
|   c   | char(1) | YES  |     |   NULL  |       |
|   i   | int(11) | YES  |     |   NULL  |       |
+-------+---------+------+-----+---------+-------+
2 rows in set (0.00 sec)

तालिका प्रकार बदलना (बदलना)

आप का उपयोग करके तालिका प्रकार का उपयोग कर सकते हैं TYPEALTER कमांड के साथ क्लॉज। बदलने के लिए निम्न उदाहरण देखेंtestalter_tbl सेवा MYISAM तालिका प्रकार।

तालिका का वर्तमान प्रकार जानने के लिए, का उपयोग करें SHOW TABLE STATUS बयान।

mysql> ALTER TABLE testalter_tbl TYPE = MYISAM;
mysql>  SHOW TABLE STATUS LIKE 'testalter_tbl'\G
*************************** 1. row ****************
           Name: testalter_tbl
           Type: MyISAM
     Row_format: Fixed
           Rows: 0
 Avg_row_length: 0
    Data_length: 0
Max_data_length: 25769803775
   Index_length: 1024
      Data_free: 0
 Auto_increment: NULL
    Create_time: 2007-06-03 08:04:36
    Update_time: 2007-06-03 08:04:36
     Check_time: NULL
 Create_options:
        Comment:
1 row in set (0.00 sec)

तालिका का नाम बदलना (बदलना)

तालिका का नाम बदलने के लिए, का उपयोग करें RENAME का विकल्प ALTER TABLE बयान।

नाम बदलने के लिए निम्नलिखित उदाहरण देखें testalter_tbl सेवा alter_tbl

mysql> ALTER TABLE testalter_tbl RENAME TO alter_tbl;

आप MySQL फ़ाइल पर INDEX कमांड बनाने और छोड़ने के लिए ALTER कमांड का उपयोग कर सकते हैं। हम अगले अध्याय में इस कमांड के बारे में विस्तार से चर्चा करेंगे।