データ定義言語(Data Definition Language, DDL)は、データを定義するためのSQL文を指します。DDLは、テーブルの作成、変更、削除など、データベースの構造を定義するために使用されます。DDLの主なコマンドには、CREATE、ALTER、DROPなどがあります。さらに、制約(constraints)を使用して、データの整合性を保つためのルールを定義することもできます。
テーブルの作成¶
CREATE TABLE文は、新しいテーブルを作成するために使用されます。書式は次のとおりです。
CREATE TABLE table_name (
column1_name data_type,
column2_name data_type,
...
);table_nameには、作成するテーブルの名前を指定します。
column1_name、column2_nameには、テーブルの列名を指定します。
data_typeには、列のデータ型を指定します。SQLiteでは、全ての値は、次の5つのstorage classのいずれかに分類されます。
- NULL
- INTEGER
- REAL
- TEXT
- BLOB
例として、usersというテーブルを作成する場合は、次のようにします。
CREATE TABLE users (
ID TEXT,
Name TEXT,
Age INTEGER
);データの追加¶
テーブルを作成した後、データを追加するには、INSERT INTO文を使用します。書式は次のとおりです。
INSERT INTO table_name (column1_name, column2_name, ...)
VALUES (value1, value2, ...);次の例では、usersテーブルにデータを追加します。
INSERT INTO users (ID, Name, Age)
VALUES ('001', 'Alice', 25);テーブルの変更¶
ALTER TABLE文は、既存のテーブルを変更するために使用されます。
列の追加¶
ADD COLUMNを使用して、テーブルに新しい列を追加することができます。書式は次のとおりです。
ALTER TABLE table_name
ADD COLUMN column_name data_type;次の例では、usersテーブルにEmail列を追加します。
ALTER TABLE users
ADD COLUMN Email TEXT;列の削除¶
DROP COLUMNを使用して、テーブルから列を削除することができます。書式は次のとおりです。
ALTER TABLE table_name
DROP COLUMN column_name;次の例では、usersテーブルからEmail列を削除します。
ALTER TABLE users
DROP COLUMN Email;テーブルの削除¶
DROP TABLE文は、テーブルを削除するために使用されます。書式は次のとおりです。
DROP TABLE table_name;次の例では、usersテーブルを削除します。
DROP TABLE users;練習1¶
- students(StudentID, Name, Age, Email)というテーブルを作成せよ。
- studentsテーブルに、
Address列を追加せよ。 - studentsテーブルから、
Email列を削除せよ。 - studentsテーブルに、
INSERT INTO文を使用して、任意のデータを追加せよ。 - studentsテーブルを削除せよ。
制約¶
主キー¶
主キー(primary key)はタプルを一意識別するために使用される。
主キーの指定(1)¶
SQLiteでは、主キーはテーブル作成時に指定することができます。
CREATE TABLE table_name (
column1_name data_type PRIMARY KEY,
column2_name data_type,
...
);以下の例では、ID列を主キーとして指定しています。
CREATE TABLE users (
ID TEXT PRIMARY KEY,
Name TEXT,
Age INTEGER
);主キーの指定(2)¶
複数の列を組み合わせて主キーを指定することもできます。
CREATE TABLE table_name (
column1_name data_type,
column2_name data_type,
...,
PRIMARY KEY (column1_name, column2_name)
);以下の例では、StudentIDとCourseIDの2つの列を主キーとして指定しています。
CREATE TABLE scores (
StudentID TEXT,
CourseID TEXT,
Score INTEGER,
PRIMARY KEY (StudentID, CourseID)
);外部キー¶
外部キー(foreign key)は、他のテーブルの主キーを参照するために使用されます。外部キーは、リレーション間の関係を表現するための制約です。
外部キーの指定(1)¶
SQLiteでは、外部キーはテーブル作成時に指定することができます。
CREATE TABLE table_name (
column_name data_type REFERENCES other_table(column_name),
...
);例えば、employees(EmployeeID, Name, DepartmentID)とdepartments(DepartmentID, DepartmentName)という2つのテーブルがあるとします。employeesテーブルのDepartmentID列は、departmentsテーブルのDepartmentID列を参照する外部キーとして指定できます。
CREATE TABLE departments (
DepartmentID TEXT PRIMARY KEY,
DepartmentName TEXT
);
CREATE TABLE employees (
EmployeeID TEXT PRIMARY KEY,
Name TEXT,
DepartmentID TEXT REFERENCES departments(DepartmentID)
);外部キーの指定(2)¶
外部キーは、下記のように指定することもできます。
CREATE TABLE table_name (
column1_name data_type,
column2_name data_type,
...,
FOREIGN KEY (column1_name) REFERENCES other_table(column_name)
);以下の例では、employeesテーブルのDepartmentID列が、departmentsテーブルのDepartmentID列を参照する外部キーとして指定されています。
CREATE TABLE departments (
DepartmentID TEXT PRIMARY KEY,
DepartmentName TEXT
);
CREATE TABLE employees (
EmployeeID TEXT PRIMARY KEY,
Name TEXT,
DepartmentID TEXT,
FOREIGN KEY (DepartmentID) REFERENCES departments(DepartmentID)
);NOT NULL制約¶
NOT NULL制約は、列にNULL値を許可しないことを指定します。NOT NULL制約は以下のように指定します。
CREATE TABLE table_name (
column_name data_type NOT NULL,
...
);以下の例では、Name列にNOT NULL制約を指定しています。
CREATE TABLE users (
ID TEXT PRIMARY KEY,
Name TEXT NOT NULL,
Age INTEGER
);NOT NULL制約を指定されていない列はNULL値を許可します。この例では、Age列はNULL値を許可します。
UNIQUE制約¶
UNIQUE制約は、列の値が一意であることを指定します。UNIQUE制約は以下のように指定します。
CREATE TABLE table_name (
column_name data_type UNIQUE,
...
);以下の例では、Email列にUNIQUE制約を指定しています。
CREATE TABLE users (
ID TEXT PRIMARY KEY,
Name TEXT,
Email TEXT UNIQUE
);CHECK制約¶
CHECK制約は、列の値が特定の条件を満たすことを指定します。CHECK制約は以下のように指定します。
CREATE TABLE table_name (
column_name data_type CHECK (expression),
...
);以下の例では、Age列にCHECK制約を指定しています。ユーザーの年齢は18歳以上でなければなりません。
CREATE TABLE users (
ID TEXT PRIMARY KEY,
Name TEXT,
Age INTEGER CHECK (Age >= 18)
);ANDやORを使用して複数の条件を組み合わせることもできます。
CREATE TABLE users (
ID TEXT PRIMARY KEY,
Name TEXT,
Age INTEGER CHECK (Age >= 18 AND Age <= 65)
);テーブルレベルの制約を指定することもできます。
CREATE TABLE table_name (
column1_name data_type,
column2_name data_type,
...,
CONSTRAINT constraint_name CHECK (expression)
);以下の例では、products(ProductID, ProductName, Price, DiscountPrice)というテーブルに、Price >= DiscountPriceという制約を指定しています。
CREATE TABLE products (
ProductID TEXT PRIMARY KEY,
ProductName TEXT,
Price REAL,
DiscountPrice REAL,
CONSTRAINT PriceCheck CHECK (Price >= DiscountPrice)
);DEFAULT制約¶
DEFAULT制約は、列にデフォルト値を指定します。DEFAULT制約は以下のように指定します。
CREATE TABLE table_name (
column_name data_type DEFAULT default_value,
...
);以下の例では、Age列にデフォルト値として18を指定しています。
CREATE TABLE users (
ID TEXT PRIMARY KEY,
Name TEXT,
Age INTEGER DEFAULT 18
);練習2¶
- departments(DepartmentID, DepartmentName)というテーブルを作成せよ。
DepartmentIDは主キーとするDepartmentNameはNULLを許可しない制約を付けよ。
- students(StudentID, Name, Age, Email, DepartmentID)というテーブルを作成せよ。
StudentIDは主キーとする。EmailはUNIQUE制約を付けよ。DepartmentIDはdepartmentsテーブルの外部キーとする。Ageは18歳以上でなければならない制約を付けよ。
- courses(CourseID, CourseName, Credits)というテーブルを作成せよ。
CourseIDは主キーとする。Creditsは1以上の整数でなければならない制約を付けよ。
- scores(StudentID, CourseID, Score)というテーブルを作成せよ。
StudentIDはstudentsテーブルの外部キーとする。CourseIDはcoursesテーブルの外部キーとする。Scoreは0以上100以下の整数でなければならない制約を付けよ。