質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.51%

  • MySQL

    7002questions

    MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

  • CakePHP

    2521questions

    CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

cakephp3でブログのカテゴリテーブルの実装についての設計質問

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 641

yajin

score 67

現在ブログのような投稿システムで、投稿する内容に0~10までのカテゴリを各ユーザが作れるようにしたいと考えています。
articlecategoryのようなものを作りたいのですが、カラム番号と一致できるようにカラムとして、
category1~10的なカラムを作りたいと考えています。テーブルに例えると、カテゴリ名を横に設計していきたいです。0はデータベースでdefault 0を設定したいとします。

①新規フィールドいつ作るのが理想か。
ユーザ情報登録時なのか、ユーザが作りたいと思ったときに作るのか。(通常ブログ記事のデフォルトでは0になっています)
できれば新規ユーザ時に登録して、ユーザがカテゴリ登録もできるのかというような認知できる設計にしたいと考えていますが、新規ユーザのユーザIDとカテゴリテーブルのIDがいつも一致できるのか心配です。userテーブルのid番号を新規登録した際にカテゴリテーブルに同じuser_idとしてフィールドを作りたい場合、どのようにすればよいのか。

$result = mysql_query($query);
$last_id = mysql_insert_id();


的なものをcakephp3ならどうするか。

②カテゴリ内の記事を全削除するためにはどうしたらよいのか。
外部キー制約でカテゴリ内の記事を全削除なんてことはできるのか?
行の削除は外部キー制約でできるが、delete from articles where user_id = 100 and category = 5; 
的なクエリを投げて全削除するべきなのかという疑問です。

③カテゴリテーブルのカラム名について
1,2,3,4というように数字はできるのか。mysqlではできるが、オブジェクト指向として取り出すときにフィールドに数字番号は可能なのでしょうか。$category->1
的な感じです。

回答によって、色々考えることが派生していくことが考えられるので、ちょっとわかりにくい質問ですがどのようにすればよいか教えてください。

追記:色々と考えていたらカラムを10個設定しなくてもよさそうな気がしてきました。
懸念していた事はユーザがカテゴリの順序を任意で変えていきたいというものでした。
id,user_id ,category_id ,category_name, created, modified
的な感じにして、modifiedでソートをかけていけば順序が保てそうです。

どうなのでしょうか。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

checkベストアンサー

0

わかる範囲で回答します。

userテーブルのid番号を新規登録した際にカテゴリテーブルに同じuser_idとしてフィールドを作りたい場合、どのようにすればよいのか。

entityをsaveするとidが自動的に設定されます。(マニュアル参照)

外部キー制約でカテゴリ内の記事を全削除なんてことはできるのか? 

DBの外部キー性制約(ON DELETE CASCADE)でもできますし、Cakeの機能を使ってもできます。

1,2,3,4というように数字はできるのか。mysqlではできるが、オブジェクト指向として取り出すときにフィールドに数字番号は可能なのでしょうか。$category->1 
的な感じです。

やったことはないですが、おそらくできないでしょう。ただし、$category->get('1')で取得できるかもしれません。ただし、その他にも制限が発生する可能性もありますし、そもそもカラム名が1というのはわかりやすくもないので、使うべきではないと思います。せめてname1やname2とするとか。基本的には追記にかかれているような方法が適切だと思います。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/10/29 17:46

    ありがとうございます。
    ずっと考えていると、id,user_id ,category_id ,category_name, created, modified というような設計になりつつありますが、ユーザがそのカテゴリの順序を設定したい場合、何かいい方法はありますでしょうか。UI的にもわかりやすい方がいいのかなと思っています。

    キャンセル

  • 2016/10/29 18:13 編集

    自分がよくやるのはsortという名前のカラムを用意して、そこに数字を入れる方法です。
    ユーザが数字を入れるのはわかりにくいので、編集画面ではsortableなどを使って、順番を指定してもらう感じですかね。
    https://jqueryui.com/sortable/

    キャンセル

  • 2016/10/29 18:34

    なるほど。
    ただ、スマートフォンでは変更できないのですよね?
    何かしらよい方法があるといいのですが・・・。

    キャンセル

  • 2016/10/29 19:13

    自分はやったことないですが、できるっぽい記事はありますね
    http://raqool.com/blog/archives/334

    まぁ、単純に「上」「下」ボタンで上下に移動するUIとかでもいいかもしれませんが。

    キャンセル

  • 2016/10/29 19:45

    >まぁ、単純に「上」「下」ボタンで上下に移動するUIとかでもいいかもしれませんが。

    なるほど。参考になりました。考えます。

    キャンセル

0

MySQL なら 削除しかり、NULL設定しかりが CREATE TABLE 時に制御可能

13.1.17.2 外部キー制約の使用

親テーブルを削除すると関連する子テーブルが自動削除を選択することも可能です。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/10/29 11:01

    フィールドにおける制約なら外部キー制約の使用ができることはわかるのですが、カラムのデータ削除の場合はdelete コマンドを使ってのほうがよさそうでしょうか。

    キャンセル

同じタグがついた質問を見る

  • MySQL

    7002questions

    MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

  • CakePHP

    2521questions

    CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。