Data Definition လို့ဆိုတဲ့အတိုင်း DDL သည် database ရဲ့ structure တွေကိုသတ်မှတ်တည်ဆောက်ခြင်း၊ ပြောင်းလဲခြင်းတွေပြုလုပ်တဲ့ query တွေအတွက်သတ်မှတ်ထားတဲ့ category ဖြစ်ပါတယ်။ Database တစ်ခုတည်ဆောက်တဲ့နေရာမှာအရေးပါတဲ့ table, column data structure တွေကိုစီမံခန့်ခွဲခြင်း၊ data integrity ကောင်းရန်အတွက် အခြားသောလိုအပ်တဲ့ စည်းမျဉ်းများကို define လုပ်ရန်အတွက်အသုံးပြုပါတယ်။ data integrity ကိုအဓိပ္ပါယ်ရှိပြီးမှန်ကန်တဲ့ dataတွေလို့အကြမ်းဖျင်းသတ်မှတ်နိုင်ပါတယ်။
DDL ကိုဝါကျတစ်ကြောင်းတည်းနဲ့နားလည်အောင်ပြောရမယ်ဆို Database တစ်ခုရုပ်လုံးပေါ်လာအောင် structure တွေသတ်မှတ်(define) လုပ်ပေးရတဲ့ query များဆိုပြီးပြောနိုင်မယ်ထင်တယ်။ ဒီအပိုင်းမှာတော့အရေးကြီးပြီးအသုံးများတဲ့ DDL queries တွေကိုလေ့လာသွားကြပါမယ်။
စမ်းချင်တာတွေစမ်းဖို့အတွက် ddl_test ဆိုတဲ့ database တစ်လုံးအရင်တည်ဆောက်လိုက်ရအောင်။
CREATE DATABASE ddl_test;
အရှေ့အပိုင်းမှာကျနော်တို့တွေ့ခဲ့ပြီးသားဖြစ်ပါတယ်။ database ထဲမှာ table တစ်လုံးတည်ဆောက်ရန်အတွက်အသုံးပြုပါတယ်။ လိုအပ်တဲ့ column နာမည်၊ structure တို့ကို define လုပ်ပြီးတည်ဆောက်နိုင်ပါတယ်။
CREATE TABLE table_name (
column_name data_type,
...,
constraint_definition
);
Students ဆိုတဲ့ table တစ်လုံးတည်ဆောက်ရအောင်။
CREATE TABLE students(
student_id INT,
name VARCHAR(50),
age INT,
remark VARCHAR (50)
);
SHOW TABLES; နဲ့ပြန်ပြီးစစ်ကြည့်နိုင်ပါတယ်။
ရှိပြီးသား table ရဲ့ structure ကိုပြောင်းလဲ ALTER TABLE ဆိုတဲ့ command ကိုအသုံးပြုပါတယ်။
table ထဲကို column အသစ်ထည့်တာ၊ ရှိပြီးသား column name ကိုပြောင်းတာ၊ column ကိုဖျက်တာစသည်ဖြင့်လုပ်ဆောင်နိုင်ပါတယ်။
ALTER TABLE table_name
ADD column_name data_type constraint_definition,
...;
ALTER TABLE students
ADD nick_name VARCHAR(50);
DESCRIBE keyword ကိုသုံးပြီးပြန်စစ်ကြည့်နိုင်ပါတယ်။
ALTER TABLE table_name
RENAME COLUMN old_column_name TO new_column_name;
ALTER TABLE students
RENAME COLUMN name TO formal_name;
DESCRIBE keyword ကိုသုံးပြီးပြန်စစ်ကြည့်နိုင်ပါတယ်။
ALTER TABLE table_name
DROP COLUMN column_name;
ALTER TABLE students
DROP COLUMN remark;
DESCRIBE keyword ကိုသုံးပြီးပြန်စစ်ကြည့်နိုင်ပါတယ်။
Table တစ်လုံးကိုဖျက်ချင်တဲ့အချိန်မှာတော့ DROP TABLE command ကိုအသုံးပြုနိုင်ပါတယ်။ table ထဲမှာသိမ်းဆည်းထားတဲ့ data တွေပါဖျက်တာဖြစ်တဲ့အတွက် ဂရုပြုဖို့လိုအပ်ပါတယ်။
DROP TABLE table_name;
DROP TABLE students;
Table column တွေသတ်မှတ်တဲ့အချိန် data integrity ရှိဖို့အတွက်အပြင် business logic အရ constraints ဆိုတာမျိုးတွေထည့်ပေးဖို့လိုအပ်တဲ့အချိန်တွေရှိပါတယ်။ constraints အကြောင်းကိုအောက်က query တွေကြည့်ပြီးဆက်လေ့လာသွားကြပါမယ်။
PRIMARY KEY ဆိုတဲ့ constraint ပေးလိုက်တဲ့ column ဟာ record တိုင်းမှာ unique (မထပ်စေရ) ဖြစ်ပြီးတော့ NULL မဖြစ်ရဘူးဆိုပြီး define လုပ်ခြင်းခံလိုက်ရပါတယ်။
Table ထဲမှာရှိတဲ့ column တစ်ခုကို primary key အဖြစ်သတ်မှတ်လိုက်မယ်ဆို အဲ့ဒီ column ဟာ record တိုင်းမှာ unique ဖြစ်သွားမယ် (duplicate value မရှိတော့ဘူးလို့ဆိုလိုခြင်း)၊ column value ကို null value အလွတ်ထည့်ပေးလို့မရတော့ပါဘူး။
CREATE TABLE table_name (
column_name data_type PRIMARY KEY,
...,
constraint_definition
);
students table ကိုအရင်ဖျက်ပါမယ်။
students table မှာ student_id ကို Primary key constraint ထည့်ပြီးတော့ဆောက်ကြည့်ပါမယ်။
CREATE TABLE students (
student_id INT PRIMARY KEY,
name VARCHAR(50),
age INT
);
DESCRIBE keyword ကိုသုံးပြီးပြန်စစ်ကြည့်နိုင်ပါတယ်။
DDL အကြောင်းရေးရင်းနဲ့မို့ တစ်လက်စတည်း FOREIGN KEY အကြောင်းပါထည့်ရေးလိုက်တာပါ။ အခုဖတ်တဲ့အချိန်နားလည်ရခက်နိုင်ပေမယ့် relationships လုပ်ရတဲ့ query တွေလေ့လာတဲ့အချိန်မှာပိုနားလည်လာပါလိမ့်မယ်။
FK ဆိုတာကတော့ column တစ်ခုရဲ့ value ကိုသုံးပြီးတော့ table တစ်လုံးနဲ့တစ်လုံးချိတ်ဆက်တဲ့နေရာမှာအသုံးပြုပါတယ်။
students table အပြင် clubs ဆိုတဲ့နော် table တစ်ခု create လုပ်ရအောင်။ ကျောင်းသားတစ်ယောက်က book club, chess club စသည်ဖြင့် club တစ်ခုခုနဲ့ချိတ်ဆက်နိုင်တဲ့ဆိုတဲ့သဘောပေါ့ဗျာ။
CREATE TABLE clubs(
club_id INT PRIMARY KEY,
club_name VARCHAR(50)
);
DROP TABLE students;
ပြီးရင်လက်ရှိ club_id ဆိုတဲ့ column ထပ်ဖြည့်ပြီး students ပြန် create လုပ်ပါမယ်။
students table ထဲက club_id ကို FK အဖြစ်သတ်မှတ်ပြီး clubs ဆိုတဲ့ table ရဲ့ primary key club_id ကိုလှမ်း reference လုပ်လိုက်ပါမယ်။
CREATE TABLE table_name (
column_name data_type,
...,
CONSTRAINT constraint_name FOREIGN KEY (column_name) REFERENCES referenced_table(referenced_column)
);
CREATE TABLE students(
student_id INT PRIMARY KEY,
name VARCHAR(50),
age INT,
club_id INT,
CONSTRAINT fk_club FOREIGN KEY (club_id) REFERENCES clubs(club_id)
);
DESCRIBE keyword ကိုသုံးပြီးပြန်စစ်ကြည့်နိုင်ပါတယ်။
ကိုယ်ဆောက်ခဲ့တဲ့ reference key ဝင်မဝင်ဆိုတာကို SHOW CREATE TABLE သုံးပြီးကြည့်ရင်ပိုမြင်နိုင်ပါတယ်။
Column value ကို NULL အထည့်မခံစေချင်တဲ့အချိန်မှာတော့ NOT NULL constraint ကိုအသုံးပြုပါတယ်။
CREATE TABLE table_name (
column_name data_type NOT NULL,
...,
constraint_definition
);
students table ကိုပြန်ဖျက်ပြီး name column ကို NOT NULL သုံးပြီးပြန်တည်ဆောက်ကြည့်ရအောင်။
ကျနော် students table ကိုပြန်ဖျက်ပြီးသုံးနေရတာက လောလောဆယ်မှာ table, column နာမည်တွေနဲ့မရှုပ်သွားစေချင်တာရယ်၊ ALTER command သုံးပြီးလုပ်လို့ရပေမယ့်လိုက်လုပ်ရတာခက်သွားမှာစိုးရိမ်မိလို့ပါ။
CREATE TABLE students(
student_id INT PRIMARY KEY,
name VARCHAR(50) NOT NULL,
age INT NOT NULL
);
DESCRIBE keyword ကိုသုံးပြီးပြန်စစ်ကြည့်နိုင်ပါတယ်။
Data insert လုပ်တဲ့အချိန်မှာ NULL value ပါလာတဲ့အခါအစားထိုးအနေနဲ့သွင်းဖို့ default value တစ်ခုခု define လုပ်တဲ့နေရာမှာအသုံးပြုပါတယ်။
CREATE TABLE table_name (
column_name data_type DEFAULT default_value,
...,
constraint_definition
);
Students table ကိုပြန်ဖျက်ပြီး age column ကို DEFAULT သုံးပြီးပြန်တည်ဆောက်ကြည့်ရအောင်။ age value က null ဖြစ်ပြီဆို 14 ကို default အနေနဲ့ထည့်ပေးမယ်ဆိုတဲ့သဘောပါ။
CREATE TABLE students (
student_id INT PRIMARY KEY,
name VARCHAR(50),
age INT DEFAULT 14
);
DESCRIBE keyword ကိုသုံးပြီးပြန်စစ်ကြည့်နိုင်ပါတယ်။
Table ထဲမှာပါတဲ့ columns တွေထဲမှာမှ unique ဖြစ်စေချင်တဲ့ column ရှိတဲ့အခါမှာအသုံးပြုပါတယ်။
CREATE TABLE table_name (
column_name data_type UNIQUE,
...,
constraint_definition
);
Students table ကိုဖျက်ပြီးတော့ name column ကို unique constraint ပေးပြီးပြန် create လုပ်ကြည့်ပါမယ်။
CREATE TABLE students(
student_id INT PRIMARY KEY,
name VARCHAR(50) UNIQUE,
age INT
);
DESCRIBE keyword ကိုသုံးပြီးပြန်စစ်ကြည့်နိုင်ပါတယ်။
အသုံးများတဲ့ DDL queries တွေဖော်ပြပေးခဲ့တာဖြစ်ပါတယ်။ တိကျသေချာတဲ့ database schema တစ်ခုထွက်လာအောင်တည်ဆောက်တဲ့နေရာမှာ DDL ကိုကျွမ်းကျင်ဖို့က အလွန်အရေးပါပါတယ်။ နောက်အပိုင်းမှာ DQL အကြောင်းကိုဆက်လေ့လာသွားကြပါမယ်။











