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

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

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

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

Q&A

解決済

2回答

810閲覧

MySQLの命名規則について質問です。

popos

総合スコア21

MySQL

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

0グッド

0クリップ

投稿2014/09/13 17:46

MySQLの命名規則でフィールド名にテーブル名を含んだほうがいいと聞いたのですが、
この理由はなんでしょうか?
下記が例になります。

例)
(Table) Accounts
(Fields) account_id, account_name, password,mail_address

アカウント用なので'account_'という接頭辞は必要ないかとも思っています。
どなたかご意見をお聞かせください。

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

フィールド名にテーブル名を含めるというのは、おそらく外部キーの話でしょうね。

isaotsunedaさんがコメントされているように、他テーブルへのリレーションのための外部キーにはテーブル名を含めることでどのテーブルへのリレーションなのか、スキーマから予想がつけやすいです。

しかしテーブル名がaccountsなのに対し、account_nameやaccount_idと言ったプリフィックスは冗長かと思います。この場合だと、name, idでも情報量は変わりませんよね。
命名規則はこれといった正解がないので曖昧な回答しかできませんが、使用されているフレームワークやO/Rマッパーにあったものを選ぶと良いのではないでしょうか。

投稿2014/09/15 11:07

the40san

総合スコア13

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

popos

2014/09/17 01:24

回答ありがとうございました!おかげで理解が深まった気がします!ありがとうござました!
guest

0

基本的にはどちらでもOKですが、私は不必要だと思います。理由としては、主キーや外部キーの場合にはテーブル名やその短縮された形のものを格納したいと考えるからです。

Accounts: id, account_name, password, mail_address
Schedules: id, account_id, schedule_date, schedule_detail

テーブルAccountsとSchedulesとの関係が1対多であるとき、Accountsの主キーidにあたるSchedulesのaccount_idが外部キーになります。この時Accountsテーブルでidをaccount_idにしてしまうと、主キーがわかりにくくなってしまいます。

投稿2014/09/15 07:30

isaotsuneda

総合スコア316

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問