上記の通りですが、
alter table articles add category_id int NOT NULL default 0 after user_id;
とすると、default値が設定できるのですが、外部キー制約のコマンドが通りません。
default値があるとできないとエラーを吐かれたのですが、
既存のテーブルにあるフィールド群に値を手動で挿入するためのクエリとはどんな方法があるのでしょうか。
追記:
users
articlecategories
articles
というテーブルがあり、
articlecategories には
id user_id category_name ~~ created modifiedなどの情報があります。
articlesには
id user_id category_id ~~ などの情報があります。
既存の記事の中で追加でカテゴリ機能を作っていこうと考えています。
エラーをはかれたので調べてみたところ
「参照先カラムにデフォルト値をセットしている」場合はエラーが出るとの記事を見かけました。
alter table articles add foreign key (category_id) references articlecategories(id) on update cascade on DELETE CASCADE;
です。
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2016/11/07 15:57
回答1件
0
ベストアンサー
外部キー制約のチェックが入り、category_idはデフォルトで0?かな?がはいっていて参照先の外部キーがどうなっているかわからないですが、articlecategoriesのidとの整合生にチェックが入り、エラーがでているので
category_idにarticlecategories.idに実際に存在する値を入れてから外部キー制約のSQLを実行するか、もしくは
SET FOREIGN_KEY_CHECKS=0; alter table articles add foreign key (category_id) references articlecategories(id) on update cascade on DELETE CASCADE; SET FOREIGN_KEY_CHECKS=1;
とりあえず、チェック飛ばして外部キー制約のコマンド通してからデータがちゃんと紐づくように値入れていかれては?
###追記
とりあえず、foreign keyのSQLが通るようには回答したつもりですが、よくよく質問文を読むと
タイトルが
MySQLで追加したカラムに値を挿入したいがdefaultは使いたくない
質問文に
既存のテーブルにあるフィールド群に値を手動で挿入するためのクエリとはどんな方法があるのでしょうか。
とありますが、しばらく考えましたが、質問の意図がわかりません。
どのカラムに何を入れたいクエリを想定されてますか?
###追記
SET FOREIGN_KEY_CHECKS=0; alter table articles add foreign key (category_id) references articlecategories(id) on update cascade on DELETE CASCADE; SET FOREIGN_KEY_CHECKS=1;
で外部キー制約を追加した後、articlesのcategory_idにはarticlecategoriesのidに存在するキーを入れる。
そうしておけばarticlecategoriesからユーザーがフィールドを削除したらそれに対応するarticlesのフィールドも削除されます。
2016/11/08 13:14と2016/11/08 13:19への回答追記
実際にどんなデータが入っているかわかりませんので、あくまでこちらの想像で簡易化して書きますが
articlecategoris.idがにたとえば今1,2,3,4,5が登録されてるとします。
その時
articlesにcategory_idというカラムを追加するのは
alter table articles add category_id int NOT NULL default 0 after user_id;
でできるが、その後articlesに対して外部キー制約を付与しようと
alter table articles add foreign key (category_id) references articlecategories(id) on update cascade on DELETE CASCADE;
を実行するとエラーがでた。
これを回避するのは上記にも書きましたが、articles.category_idの値をarticlecategoris.idに存在する値1,2,3,4,5のどれかが入っていいとチェックが入りSQLを成功できない。
なので方法として先に1,2,3,4,5の値を入れてから外部キー制約を実行するか、SQL実行時外部キーの整合生のチェックが入らないように
SET FOREIGN_KEY_CHECKS=0;
で外部キーチェックを無効にしてarticles.category_idを0のまま外部キー制約を付与するの2つを回答しました。
もちろんその後外部キーチェックをしてもらわないといけないので
SET FOREIGN_KEY_CHECKS=1;
で戻しておく。
そしてここからですが、もしSET FOREIGN_KEY_CHECKS=0の方法で追加した場合、データ的には
articles.category_idとarticlecategoris.idの整合生がおかしいままなのでarticles.category_idに1,2,3,4,5の中からデータを入れないといけない。
ここまでOKですか?
もし今後articlesにフィールドを追加する場合もarticles.category_idにはarticlecategoris.idの中に存在する値を指定しないと
defaultの0は入れる事ができないので、無理です。
なのでこの解決方法はarticlesにフィールド追加する際にはarticles.category_idを未指定(defaultの値が使われる)でのinsertは行わない。
という方法か、
defaultが0になっているのをdefaultを(確実に存在する値)1などにしてエラーが出ないようにする。
こちら側でarticlecategories.id が1に「カテゴリなし」的な感じにしたフィールドをこちら側で1個挿入しておくべきでしょうか。
テーブルの名前からブログのカテゴリーのような感じなのかな?と思いますので、その方法はあだと思います。
articles.category_idのdefault値を1に変更、articlecategoris.idの1はカテゴリなしというようなフィールドにしておく
articles.category_idを未指定でinsertした記事はカテゴリーなしとして登録される。
という流れになるので良いと思います。
投稿2016/11/07 16:20
編集2016/11/08 05:04総合スコア1689
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2016/11/07 16:34
2016/11/07 16:56
2016/11/08 04:14
2016/11/08 04:19
2016/11/08 05:05
2016/11/08 06:13
2016/11/08 06:20
2016/11/08 06:26
2016/11/08 06:32
2016/11/08 06:32
2016/11/08 07:00
2016/11/08 07:15
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
質問の解決につながる回答をしましょう。 サンプルコードなど、より具体的な説明があると質問者の理解の助けになります。 また、読む側のことを考えた、分かりやすい文章を心がけましょう。