
はじめまして。
質問があります。
MySQLを使用しているのですが、以下を見てください。
----------------------------------------------------------------
mysql> create table vendors
-> (
-> vend_id char(10) NOT NULL,
-> vend_name char(50) NOT NULL,
-> vend_zip char(10),
-> vend_state char(10),
-> vend_city char(50),
-> vend_address char(50),
-> primary key(vend_id)
-> ) TYPE=MyISAM;
Query OK, 0 rows affected (0.38 sec)
mysql> create table products
-> (
-> prod_id char(10) NOT NULL,
-> vend_id char(10) NOT NULL,
-> prod_name char(255) NOT NULL,
-> prod_price decimal(8,0) NOT NULL,
-> prod_desc blob,
-> primary key(prod_id),
-> foreign key(vend_id) references vendors(vend_id)
-> ) TYPE=MyISAM;
Query OK, 0 rows affected (0.05 sec)
----------------------------------------------------------------
外部キーを設定したつもりなのですが、desc productsを実行すると
キーフィールドに「pri」と表示されているので、主キーが
設定されていることが確認できるのですが、外部キーが設定されて
いることは確認できません。外部キーは設定されているのでしょうか?
もし設定されていないのなら、どのようにすればよいのでしょうか?
また、外部キーが設定されていることを確認するにはどうすれば
よいでしょうか?ご教授お願いします。
No.1ベストアンサー
- 回答日時:
MySQLのバージョンが不明なので、
私が使っていた4.1では、MyIsamに対してFOREIGN KEY制約
はつけることができませんでした。
参照先・元共にInnoDBでないとだめです。
下の参考URLに記載されています。
また、参照方法ですが、参考URLの一番下にある
SHOW TABLE STATUS FROM yourdatabasename LIKE 'T'
このコマンドで参照することができるのではないでしょうか?
参考URL:http://dev.mysql.com/doc/refman/4.1/ja/innodb-fo …
naochancom様へ
ご回答ありがとうございした。
連絡が遅れましてすみませんでした。
MySQLのバージョンは3.23.49でした。
今日MySQL5.0をインストールしてInnoDB
で作成してみようと思います。
ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- MySQL `picture` varchar(255) のコマンドで間違いないでしょうか? 1 2022/11/21 04:08
- MySQL エラー 1068 (42000): 複数の主キーが定義されていますエラー 2 2022/11/17 04:36
- MySQL my_itemsテーブルのIDにAUTO_INCREMENT を追加ができるかで 1 2023/01/03 09:09
- MySQL テーブル作成です。どこかのスペルが間違っているか記号など スペースかな? 1 2022/10/01 05:08
- MySQL SHOW CREATE TABLE posts;これって何ですか? 3 2022/08/28 22:57
- MySQL PHPとMySQLを使った掲示板の作り方 1 2022/06/02 13:00
- MySQL あと、MySQLの文字コードはutf8 気になりますね 1 2022/12/01 07:22
- MySQL MYSQL エラー 2 2022/10/18 11:37
- PHP php テーブルが作成できない 1 2022/11/17 23:41
- MySQL php テーブルを作れない 2 2022/11/17 18:22
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
テーブル作成について質問があ...
-
DDLのインポート方法
-
PHP+MySQLで文が正しいのに実行...
-
SQLiteでご教示願います。
-
UPDATE文のエラー直せますでし...
-
SELECT クエリーの OR の使い方...
-
この場合の賢いSQL文は?
-
テーブルが5つの時の結合の仕...
-
複数のテーブルを使ってselect...
-
エクセルの関数について教えて...
-
2つのテーブルからグループ別け...
-
テーブル結合でのカウント処理
-
sqlのVIEWの作り方
-
クエリの遅さの原因
-
mysqlのインデックスについて質...
-
PHP/MySQL INSERT文について。
-
特定の範囲のデータを削除するには
-
途中からプライマリーキーを作成
-
mysqlのデータの表示順番を変え...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
エクセルの関数について教えて...
-
select文のwhere句に配列を入れ...
-
VIEWの元のテーブルのindexって...
-
エラー 1068 (42000): 複数の主...
-
SQLにて特定の文字を除いた検索...
-
【Transact-sql】 execの結果を...
-
マイクラPC版のコマンドで効率...
-
SQL Left Join で重複を排除す...
-
sqlで、600行あるテーブルを100...
-
複数テーブルのGROUP BY の使い...
-
WordpressのContact form 7でzi...
-
クエリ表示と、ADOで抽出したレ...
-
SQLサーバから、項目の属性(型...
-
selectした大量データをinsert...
-
Access パラメータクエリをcsv...
-
副問合せの書き方について
-
inner joinをすると数がおかし...
-
insertを高速化させたい
-
[MySQL] 3つのテーブルの結合で...
おすすめ情報