MySQLi - ALTER कमांड

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

आइए एक तालिका के निर्माण के साथ शुरू करें tutorials_alter

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

mysql> use TUTORIALS;
Database changed

mysql> create table tutorials_alter
   -> (
   -> i INT,
   -> c CHAR(1)
   -> );
Query OK, 0 rows affected (0.27 sec)

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

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

मान लीजिए कि आप किसी मौजूदा कॉलम को छोड़ना चाहते हैं i MySQLi table के ऊपर से आप उपयोग करेंगे DROP साथ खंड ALTER आदेश निम्नानुसार है -

mysql> ALTER TABLE tutorials_alter  DROP i;

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

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

mysql> ALTER TABLE tutorials_alter ADD i INT;

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

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

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

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 क्लॉज के साथ काम करते हैं। इसका मतलब यह है कि यदि आप किसी मौजूदा कॉलम को किसी तालिका के भीतर बदलना चाहते हैं, तो आपको पहले उसे डीआरओपी करना होगा और फिर उसे नए स्थान पर जोड़ना होगा।

स्तंभ की परिभाषा या नाम बदलना

कॉलम की परिभाषा बदलने के लिए, का उपयोग करें MODIFY या CHANGEALTER कमांड के साथ क्लॉज। उदाहरण के लिए, कॉलम बदलने के लिएc CHAR (1) से CHAR (10) तक, यह करें -

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

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

mysql> ALTER TABLE tutorials_alter CHANGE i j BIGINT;

यदि आप अब स्तंभ नाम को बदले बिना BINTINT से INT में बदलने के लिए CHANGE का उपयोग करते हैं, तो कथन अपेक्षित होगा -

mysql> ALTER TABLE tutorials_alter CHANGE j j INT;

अशक्त और डिफ़ॉल्ट मान विशेषताओं पर अन्य तालिका का प्रभाव -

जब आप किसी कॉलम को मोडिफाई या चेंज करते हैं, तो आप यह भी निर्दिष्ट कर सकते हैं कि कॉलम में NULL मान हो सकते हैं या नहीं और इसका डिफ़ॉल्ट मान क्या है। वास्तव में, यदि आप ऐसा नहीं करते हैं, तो MySQLi स्वचालित रूप से इन विशेषताओं के लिए मान प्रदान करता है।

यहाँ उदाहरण है, जहाँ NULL कॉलम डिफ़ॉल्ट रूप से मान 100 नहीं होगा।

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

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

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

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

mysql> ALTER TABLE tutorials_alter ALTER j SET DEFAULT 1000;
mysql> SHOW COLUMNS FROM tutorials_alter;
+-------+------------+------+-----+---------+-------+
| Field | Type       | Null | Key | Default | Extra |
+-------+------------+------+-----+---------+-------+
| c     | char(10)   | YES  |     | NULL    |       |
| j     | bigint(20) | NO   |     | 1000    |       |
+-------+------------+------+-----+---------+-------+
2 rows in set (0.02 sec)

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

mysql> ALTER TABLE tutorials_alter ALTER j DROP DEFAULT;
mysql> SHOW COLUMNS FROM tutorials_alter;
+-------+------------+------+-----+---------+-------+
| Field | Type       | Null | Key | Default | Extra |
+-------+------------+------+-----+---------+-------+
| c     | char(10)   | YES  |     | NULL    |       |
| j     | bigint(20) | NO   |     | NULL    |       |
+-------+------------+------+-----+---------+-------+
2 rows in set (0.02 sec)

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

आप तालिका प्रकार का उपयोग करके उपयोग कर सकते हैं TYPE ALTER कमांड के साथ क्लॉज।

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

mysql>  SHOW TABLE STATUS LIKE 'tutorials_alter'\G
*************************** 1. row ***************************
           Name: tutorials_alter
         Engine: InnoDB
        Version: 10
     Row_format: Compact
           Rows: 0
 Avg_row_length: 0
    Data_length: 16384
Max_data_length: 0
   Index_length: 0
      Data_free: 0
 Auto_increment: NULL
    Create_time: 2017-02-17 11:30:29
    Update_time: NULL
     Check_time: NULL
      Collation: latin1_swedish_ci
       Checksum: NULL
 Create_options:
        Comment:
1 row in set (0.00 sec)

एक तालिका का नाम बदलना

तालिका का नाम बदलने के लिए, का उपयोग करें RENAMEवैकल्पिक तालिका विवरण का विकल्प। नीचे दिए गए उदाहरण को आजमा कर देखें tutorial_alter को tutorial_bks नाम बदलने के लिए।

mysql> ALTER TABLE tutorials_alter RENAME TO tutorials_bks;

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