MySQL သည် နယ်ပယ်အများအပြားတွင် ရာထူးတိုးမြှင့်ရန် ပေါင်းထည့်ခြင်းကို ပြောင်းလဲပါသလား။ modify column statement ၏ အသုံးပြုပုံ အသေးစိတ်ရှင်းပြချက်

က MySQL နယ်ပယ်အများအပြားတွင် ရာထူးတိုးမြှင့်ရန် အပြောင်းအလဲကို ပေါင်းထည့်ပါသလား။ modify column statement ၏ အသုံးပြုပုံ အသေးစိတ်ရှင်းပြချက်

က MySQL ALTER အမိန့်

ဒေတာဇယားအမည်ကို မွမ်းမံရန် သို့မဟုတ် ဒေတာဇယားကွက်လပ်များကို ပြင်ဆင်ရန် လိုအပ်သည့်အခါ၊ ကျွန်ုပ်တို့သည် MySQL ALTER အမိန့်ကို အသုံးပြုရန် လိုအပ်သည်။

ဤသင်ခန်းစာကို မစတင်မီ၊ testalter_tbl အမည်ရှိ ဇယားတစ်ခုကို ဖန်တီးကြပါစို့။

root@host# mysql -u root -p password;
Enter password:*******
mysql> use chenweiliang;
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)

ဇယားကွက်များကို ဖျက်ရန်၊ ထည့်ရန် သို့မဟုတ် ပြင်ဆင်ပါ။

အောက်ဖော်ပြပါ command သည် အထက်တွင်ဖန်တီးထားသောဇယား၏ i ကော်လံကိုချရန် DROP အပိုဒ်ဖြင့် ALTER command ကိုအသုံးပြုသည်-

mysql> ALTER TABLE testalter_tbl  DROP i;

ဒေတာဇယားတွင် ကွက်လပ်တစ်ခုသာကျန်ရှိလျှင် အကွက်တစ်ခုကို ဖျက်ရန် DROP ကို ​​အသုံးမပြုနိုင်ပါ။

ဒေတာဇယားသို့ ကော်လံများထည့်ရန် ADD clause ကို MySQL တွင်အသုံးပြုပါသည်။ အောက်ပါဥပမာသည် i field ကို table testalter_tbl တွင် ထည့်သွင်းပြီး ဒေတာအမျိုးအစားကို သတ်မှတ်သည်-

mysql> ALTER TABLE testalter_tbl ADD i INT;

အထက်ပါ command ကိုလုပ်ဆောင်ပြီးနောက်၊ i field သည် data table fields ၏အဆုံးတွင် အလိုအလျောက်ထည့်သွင်းမည်ဖြစ်သည်။

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)

အကွက်အသစ်၏တည်နေရာကို သတ်မှတ်ရန် လိုအပ်ပါက၊ MySQL မှပေးသော FIRST သော့ချက်စာလုံးကို အသုံးပြုနိုင်သည်။တည်နေရာပထမကော်လံ)၊ AFTER အကွက်အမည် (အကွက်တစ်ခုပြီးနောက် သတ်မှတ်)။

အောက်ပါ 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 clause တွင်သာအသုံးပြုသည်၊ ထို့ကြောင့် data table field ၏အနေအထားကိုပြန်လည်သတ်မှတ်လိုပါက DROP ကိုအသုံးပြုပြီး အကွက်ကိုဖယ်ရှားပြီးနောက် အကွက်ကိုထည့်ရန် ADD ကိုအသုံးပြုရန်လိုအပ်ပါသည်။


အကွက်အမျိုးအစားနှင့် အမည်ကို ပြင်ဆင်ပါ။

အကယ်၍ သင်သည် အကွက်အမျိုးအစားနှင့် အမည်ကို ပြုပြင်ရန် လိုအပ်ပါက၊ သင်သည် ALTER ညွှန်ကြားချက်တွင် MODIFY သို့မဟုတ် CHANGE အပိုဒ်ကို အသုံးပြုနိုင်သည်။

ဥပမာအားဖြင့်၊ အကွက်အမျိုးအစား c ကို CHAR(1) မှ CHAR(10) သို့ ပြောင်းရန်၊ အောက်ပါ command ကို လုပ်ဆောင်ပါ-

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

CHANGE clause နှင့် syntax သည် အလွန်ကွဲပြားပါသည်။သော့ချက်စကားလုံးကို ပြောင်းလဲပြီးနောက် ချက်ခြင်းတွင် သင်မွမ်းမံလိုသော အကွက်အမည်ဖြစ်ပြီး နယ်ပယ်အသစ်အမည်နှင့် အမျိုးအစားကို သတ်မှတ်ပါ။အောက်ပါ ဥပမာကို စမ်းကြည့်ပါ။

mysql> ALTER TABLE testalter_tbl CHANGE i j BIGINT;

mysql> ALTER TABLE testalter_tbl CHANGE j j INT;

Null နှင့် Default တန်ဖိုးများအပေါ် ALTER TABLE ၏အကျိုးသက်ရောက်မှု

အကွက်တစ်ခုကို သင်ပြင်ဆင်သောအခါတွင်သာ ထည့်သွင်းခြင်းရှိမရှိ သို့မဟုတ် ပုံသေတန်ဖိုးတစ်ခု သတ်မှတ်ရန် သတ်မှတ်နိုင်သည်။

အောက်ပါဥပမာတွင် အကွက် j သည် 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)
Changing a Table Type:

ဒေတာဇယားအမျိုးအစားကို မွမ်းမံပြင်ဆင်ခြင်းသည် ALTER အမိန့်နှင့် TYPE အပိုဒ်ကို အသုံးပြု၍ လုပ်ဆောင်နိုင်သည်။ကျွန်ုပ်တို့သည် ဇယား testalter_tbl အမျိုးအစားကို MYISAM သို့ပြောင်းသည့် အောက်ပါဥပမာကို စမ်းကြည့်ပါ။

မှတ်စုဒေတာဇယားအမျိုးအစားကိုကြည့်ရှုရန်၊ သင်သည် SHOW TABLE STATUS ထုတ်ပြန်ချက်ကို အသုံးပြုနိုင်သည်။

mysql> ALTER TABLE testalter_tbl ENGINE = 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)

ဇယားအမည်ကို ပြင်ဆင်ပါ။

ဒေတာဇယား၏အမည်ကို ပြင်ဆင်ရန် လိုအပ်ပါက၊ ထိုသို့ပြုလုပ်ရန် ALTER TABLE ထုတ်ပြန်ချက်တွင် RENAME အပိုဒ်ကို အသုံးပြုနိုင်သည်။

ဒေတာဇယား testalter_tbl ကို alter_tbl သို့ အမည်ပြောင်းရန် အောက်ပါဥပမာကို စမ်းကြည့်ပါ။

mysql> ALTER TABLE testalter_tbl RENAME TO alter_tbl;

ALTER command ကို MySQL ဇယားများတွင် အညွှန်းများဖန်တီးရန်နှင့် ဖျက်ရန်အတွက်လည်း အသုံးပြုနိုင်ပြီး၊ နောက်အခန်းများတွင် ကျွန်ုပ်တို့ပါဝင်ပါမည်။

အခြားအသုံးပြုမှုများကို ပြောင်းလဲပါ။

သိုလှောင်မှုအင်ဂျင်ကို မွမ်းမံပြင်ဆင်ပါ- ၎င်းကို myisam သို့ ပြင်ဆင်ပါ။

alter table tableName engine=myisam;

နိုင်ငံခြားကီးကန့်သတ်ချက်ကို ဖယ်ရှားပါ- သော့အမည်သည် နိုင်ငံခြားသော့အမည်တူတစ်ခုဖြစ်သည်။

alter table tableName drop foreign key keyName;

မွမ်းမံထားသောအကွက်၏ နှိုင်းရအနေအထား- ဤနေရာတွင် name1 သည် သင်မွမ်းမံလိုသောအကွက်ဖြစ်ပြီး အမျိုးအစား 1 သည် အကွက်၏မူလအမျိုးအစားဖြစ်ပြီး ပထမနှင့်နောက်၊ ထင်ရှားသင့်သည်၊ မည်သည့်အရာသည် ပထမဖြစ်သည်၊ ပထမသည် ပထမနေရာဖြစ်ပြီး နောက်သည် name2 အကွက်နောက်မှာ ထားလိုက်ပါ။

alter table tableName modify name1 type1 first|after name2;

မျှော်လင့်ခြင်း Chen Weiliang ဘလော့ဂ် ( https://www.chenweiliang.com/ ) shared "MySQL သည် နယ်ပယ်အများအပြားတွင် ရာထူးတိုးမြှင့်ရန် ပေါင်းထည့်ခြင်းအား ပြောင်းလဲခြင်းလား။ Modify Column Statement" အသုံးပြုပုံအသေးစိတ်ရှင်းပြချက်သည် သင့်အတွက် အထောက်အကူဖြစ်စေပါသည်။

ဤဆောင်းပါး၏ link ကိုမျှဝေရန်ကြိုဆိုပါတယ်:https://www.chenweiliang.com/cwl-495.html

နောက်ဆုံးထွက်မွမ်းမံမှုများကို ရယူရန် Chen Weiliang ၏ တယ်လီဂရမ်ချန်နယ်မှ ကြိုဆိုပါသည်။

🔔 ချန်နယ်ထိပ်တန်းလမ်းညွှန်တွင် တန်ဖိုးရှိသော "ChatGPT အကြောင်းအရာစျေးကွက်ရှာဖွေရေး AI ကိရိယာအသုံးပြုမှုလမ်းညွှန်" ကို ပထမဆုံးရရှိသူဖြစ်လိုက်ပါ။ 🌟
📚 ဤလမ်းညွှန်တွင် တန်ဖိုးကြီးကြီးမားမားပါရှိသည်၊ 🌟ဒါက ရှားပါးအခွင့်အရေးပါ၊ လက်လွတ်မခံပါနဲ့။ ⏰⌛💨
ကြိုက်ရင် Share ပြီး Like လုပ်ပါ။
သင်၏မျှဝေခြင်းနှင့် လိုက်ခ်များသည် ကျွန်ုပ်တို့၏ စဉ်ဆက်မပြတ်လှုံ့ဆော်မှုဖြစ်သည်။

 

မှတ်ချက်များ

သင့်ရဲ့အီးမေးလ်လိပ်စာကိုထုတ်ဝေမည်မဟုတ် 用项已用用 * တံဆိပ်

အပေါ်မှလှိမ့်