複数の列にFOREIGNKEY制約を割り当てるにはどうすればよいですか?
MySQLでは、テーブルの複数の列にFOREIGNKEY制約を追加できます。条件は、子テーブルの各外部キーが異なる親テーブルを参照する必要があることです。
次のように、フィールド「cust_unq_id」に主キー制約があるテーブル「customer2」があるとします-
mysql> describe customer2; +-------------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +-------------+-------------+------+-----+---------+-------+ | cust_id | int(11) | YES | | NULL | | | First_name | varchar(20) | YES | | NULL | | | Last_name | varchar(20) | YES | | NULL | | | City | varchar(10) | YES | | NULL | | | cust_unq_id | int(11) | NO | PRI | 0 | | +-------------+-------------+------+-----+---------+-------+ 5 rows in set (0.06 sec)
また、親テーブル「customer」を参照するフィールド「Cust_id」に外部キー制約がすでに設定されているテーブルorders1があります。
mysql> describe orders1; +--------------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------------+-------------+------+-----+---------+-------+ | order_id | int(11) | NO | PRI | NULL | | | Product_name | varchar(25) | YES | | NULL | | | orderdate | date | YES | | NULL | | | Cust_id | int(11) | YES | MUL | NULL | | | cust_unq_id | int(11) | YES | | NULL | | +--------------+-------------+------+-----+---------+-------+ 5 rows in set (0.04 sec)
ここで、次のALTER TABLEクエリを使用して、親テーブル「customer2」を参照するフィールド「cust_unq_id」に別の外部キー制約を追加できます。
mysql> Alter table orders1 add FOREIGN KEY(cust_unq_id) REFERENCES Customer2(Cust_unq_id); Query OK, 0 rows affected (0.25 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql> describe orders1; +--------------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------------+-------------+------+-----+---------+-------+ | order_id | int(11) | NO | PRI | NULL | | | Product_name | varchar(25) | YES | | NULL | | | orderdate | date | YES | | NULL | | | Cust_id | int(11) | YES | MUL | NULL | | | cust_unq_id | int(11) | YES | MUL | NULL | | +--------------+-------------+------+-----+---------+-------+ 5 rows in set (0.06 sec)
上記の結果セットから、「orders1」テーブルには2つあり、1つは「cust_id」に、もう1つは「cust_unq_id」外部キー制約にあることがわかります。
-
MySQLテーブルの列の名前を取得するにはどうすればよいですか?
これにはSHOWコマンドを使用できます。 以下は構文です- show columns from yourTableName; まずテーブルを作成しましょう- mysql> create table DemoTable ( StudentId int NOT NULL AUTO_INCREMENT PRIMARY KEY, StudentFirstName varchar(20), StudentLastName varchar(20), StudentAge int,  
-
MySQL DBで外部キーを識別する方法は?
最初にテーブルを作成しましょう- mysql> create table DemoTable1 (Id int NOT NULL PRIMARY KEY,EmployeeName varchar(100)); Query OK, 0 rows affected (0.50 sec) 以下は、外部キー制約を持つ2番目のテーブルを作成するためのクエリです- mysql> create table DemoTable2 ( Id int NOT NULL, StreetName