このジャンルでお願いします。
例えば次のようなアカウント情報を格納するテーブルがあったとして
CREATE TABLE user (
id int(11) NOT NULL AUTO_INCREMENT,
name varchar(64),
email varchar(64),
password varchar(64),
PRIMARY KEY(id)
);
idカラム名を「id」か「user_id」にするか悩んでいます。
自分としては「id」のままで良いと思っているのですが、
参考書や他の方のやり方を見てると「user_id」のようにしてる方もいます。
「user_id」にすることによってSQL文を見た時にも何のidかすぐ分かるし、
USING句を使えるなどのメリットがあるのでたしかにこちらの方が良いかなぁとは思うのですが、
「user_id」にするなら統一性をもたせるために「name」も「user_name」にするのか、
「email」も「user_email」にするのか、などキリがないというか・・・
そういう理由もあって自分としては「id」のままなのですが、
みなさんはどちらのやり方をされているのでしょうか?
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
>例えば、楽天なんかはメールアドレスをログインのキー(ID)にしてますよね?
>当然メールアドレスがuniqueになると思うのですが、
>その場合オートインクリメントidなどは設けているのでしょうか?
楽天が実際にどうしているかはわかりませんが、
ログイン名は当然ユニークな属性をつけているはずです。
ただし、ユーザー管理テーブルの場合ログイン名がプライマリーキーになることはまれで
(1)ログイン名を変更しようとした場合
(2)ユーザーごとにログイン情報の履歴をとる場合
には、別のidが(裏で)利用されていると考えるのが妥当です。
(1)だと、メールアドレスはさまざまな理由で変更になる場合があります
ユーザーIDさえ不変であればメールアドレスを何らかの方法で修正すれば
別のアドレスでも個人情報をひきつげます。
(2)の場合、フラグとからめればログイン名やユーザーIDは単一でユニークである
必要はありません。
ユーザーID+フラグで複合のユニーク属性をつけると、修正履歴をもつことができます
ユーザーに実際に見せたり、ログインに利用したりするのはフラグの特定番号
たとえばフラグ=0のものは現在のユーザー情報、フラグ=1~5を履歴、などと定義すれば
ユーザー管理の幅が広がります。
もちろん正規化して別テーブルで可変の履歴をとればフラグを使う必要はありません
No.1
- 回答日時:
ユーザーテーブルの中だけでいえばidでもuseridでもuidでもなんでもかまいません。
別テーブルから参照する場合、idとしているとそれが何のidかをわかるように
命名した方が使いやすくなります。
RDBの場合、ほとんどのテーブルは「参照される」ので
テーブルごとに異なるidでレコードを管理する場合、idという名称が
競合するため、結果としてidよりuser_idの方が使い勝手がよいでしょう。
おなじようにnameもuserの氏名としてしか使わないなら問題ありませんが
companyテーブルにnameを設定しているならunameとcnameに分けた方がよいです。
ただし・・・
今回のようにオートインクリメントでidを設定する場合、参照性が薄いかもしれません
単にレコードをユニークに判別するためのidで参照につかわないのであれば
idのままでもOKです。
その場合、ユーザーを特定するための別の個別idをuser_idにした方がよいです。
たとえば社員番号とかその手の管理番号。
ご回答ありがとうございます。
>おなじようにnameもuserの氏名としてしか使わないなら問題ありませんが
>companyテーブルにnameを設定しているならunameとcnameに分けた方がよいです。
なるほど、他のテーブルにあるかという基準で考えればいいわけですね。
参考になりました。
本題からずれて申し訳ないのですが、
一般的にアカウントを格納するテーブルのカラム構成ってどのようになってるのでしょうか?
例えば、楽天なんかはメールアドレスをログインのキー(ID)にしてますよね?
当然メールアドレスがuniqueになると思うのですが、
その場合オートインクリメントidなどは設けているのでしょうか?
そのサイトの目的によってアカウントテーブルの構成は異なってくるとは思うのです、
必要最小限のカラムで構成する場合にyambejpさんならどのような構成にするのか教えて頂けないでしょうか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- MySQL PHPとMySQLを使った掲示板の作り方 1 2022/06/02 13:00
- MySQL エラー 1068 (42000): 複数の主キーが定義されていますエラー 2 2022/11/17 04:36
- MySQL `picture` varchar(255) のコマンドで間違いないでしょうか? 1 2022/11/21 04:08
- MySQL テーブル作成です。どこかのスペルが間違っているか記号など スペースかな? 1 2022/10/01 05:08
- MySQL php テーブルを作れない 2 2022/11/17 18:22
- PHP php テーブルが作成できない 1 2022/11/17 23:41
- JavaScript Json のキーと値の出力の違いについて 2 2022/06/14 20:22
- MySQL MYSQL エラー 2 2022/10/18 11:37
- MySQL あと、MySQLの文字コードはutf8 気になりますね 1 2022/12/01 07:22
- MySQL my_itemsテーブルのIDにAUTO_INCREMENT を追加ができるかで 1 2023/01/03 09:09
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
副問合せの書き方について
-
sqlで、600行あるテーブルを100...
-
書籍の内容はまともでしょうか?
-
SQLサーバから、項目の属性(型...
-
阪急三番街 ATM(ゆうちょ)は...
-
【MySQL】本当に困っているので...
-
DataTableで重複行を削除したい
-
SQL Left Join で重複を排除す...
-
Unionした最後にGROUP BYを追加...
-
1対多結合で多を絞り込み条件と...
-
php+mysqlで複数選択削除について
-
PL/SQLの変数について
-
[MySQL] UNIQUE制約の値を更新...
-
LAST_INSERT_IDで同時にアクセ...
-
Access パラメータクエリをcsv...
-
画像とカテゴリーを出力したい...
-
マイクラPC版のコマンドで効率...
-
Mysql でレコードを追加した時...
-
VMwareがCDドライブを認識する...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
SQL Left Join で重複を排除す...
-
副問合せの書き方について
-
SQLサーバから、項目の属性(型...
-
VIEWの元のテーブルのindexって...
-
select文のwhere句に配列を入れ...
-
selectした大量データをinsert...
-
センノシド異性体構造式
-
Unionした最後にGROUP BYを追加...
-
insertを高速化させたい
-
SQLにて特定の文字を除いた検索...
-
マイクラPC版のコマンドで効率...
-
ある条件の最大値+1を初番する...
-
inner joinをすると数がおかし...
-
sqlで、600行あるテーブルを100...
-
エクセルの関数について教えて...
-
Access パラメータクエリをcsv...
-
URL と行番号の指定
-
複数テーブルのGROUP BY の使い...
-
PL/SQLの変数について
おすすめ情報