ဆောင်းပါးလမ်းညွှန်
က 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 ၏ တယ်လီဂရမ်ချန်နယ်မှ ကြိုဆိုပါသည်။
📚 ဤလမ်းညွှန်တွင် တန်ဖိုးကြီးကြီးမားမားပါရှိသည်၊ 🌟ဒါက ရှားပါးအခွင့်အရေးပါ၊ လက်လွတ်မခံပါနဲ့။ ⏰⌛💨
ကြိုက်ရင် Share ပြီး Like လုပ်ပါ။
သင်၏မျှဝေခြင်းနှင့် လိုက်ခ်များသည် ကျွန်ုပ်တို့၏ စဉ်ဆက်မပြတ်လှုံ့ဆော်မှုဖြစ်သည်။