MySQLバージョン4.1.16を使用しています。
基本となるユーザ情報を格納するテーブルで、
自動インクリメントされるidというカラムを使用する場合と、
使用しない場合とでは、どちらが良いというのはあるのでしょうか?
みなさんはどちらの形で利用しているのでしょうか?
[userinfoテーブル] id使用
id UNSIGNED AUTO_INCREMENT PRIMARY KEY
user_id VARCHAR(12) UNIQUE
password TINYTEXT
[userinfoテーブル] id使用しない
user_id VARCHAR(12) PRIMARY KEY
password TINYTEXT
No.1ベストアンサー
- 回答日時:
user_id列は、どういう形式なのですか?
意味のない一意な通番を主キーにする方法は、サロゲート・キーと呼ばれます。
サロゲート・キーは、例えば次のような観点で、要否を判断します。
(1)行を一意に識別できる列の有無
(2)(1)の列のコード体系が変更される可能性
(3)関連する表数や行数
(4)「日時型」や「時間型」だけでは識別できない精度で、順序を示す値が必要か?
一意に識別でき、変更の可能性が殆どないようなキーを持つなら、サロゲート・キーをあえて持つ必要はありません。
>user_id VARCHAR(12) UNIQUE
大規模なシステムで性能を確保する場合、重複チェックのオーバーヘッドも無視できません。
>password TINYTEXT
性能を気にするなら、TEXT系の列は、事前に最大長が分からない場合にのみ使用しましょう。TEXT型の列値は、物理的に別のレコードとして格納されるため、I/O増になってしまいます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- MySQL PHPとMySQLを使った掲示板の作り方 1 2022/06/02 13:00
- MySQL MYSQL エラー 2 2022/10/18 11:37
- MySQL my_itemsテーブルのIDにAUTO_INCREMENT を追加ができるかで 1 2023/01/03 09:09
- SQL Server ACCESSで複数テーブルを結合して、リストを作る方法を教えてください。 2 2022/08/12 19:32
- SQL Server ACCESSで3ファイルを結合して、表を作成するやり方を教えて下さい。 17 2022/08/15 20:34
- MySQL エラー 1068 (42000): 複数の主キーが定義されていますエラー 2 2022/11/17 04:36
- MySQL テーブル作成です。どこかのスペルが間違っているか記号など スペースかな? 1 2022/10/01 05:08
- PHP php テーブルが作成できない 1 2022/11/17 23:41
- MySQL `picture` varchar(255) のコマンドで間違いないでしょうか? 1 2022/11/21 04:08
- MySQL php テーブルを作れない 2 2022/11/17 18:22
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
Access パラメータクエリをcsv...
-
SQL Left Join で重複を排除す...
-
副問合せの書き方について
-
Unionした最後にGROUP BYを追加...
-
PL/SQLの変数について
-
android studio
-
VIEWの元のテーブルのindexって...
-
SQLite3でこんな便利なSQLはで...
-
selectした大量データをinsert...
-
複数のExcelアドインひとつのタ...
-
1テーブル&複数レコードの更新...
-
”photo id” とは何ぞや?
-
ある条件の最大値+1を初番する...
-
verilogに適したvimの設定を探...
-
group byのSQLでインデックスを...
-
insertを高速化させたい
-
親と子供が複数のSQL取得方法
-
テーブル作成です。どこかのス...
-
クエリ表示と、ADOで抽出したレ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
SQL Left Join で重複を排除す...
-
VIEWの元のテーブルのindexって...
-
SQLサーバから、項目の属性(型...
-
select文のwhere句に配列を入れ...
-
副問合せの書き方について
-
マイクラPC版のコマンドで効率...
-
Unionした最後にGROUP BYを追加...
-
selectした大量データをinsert...
-
SQLにて特定の文字を除いた検索...
-
[SQLServer] テーブル名からカ...
-
1テーブル&複数レコードの更新...
-
inner joinをすると数がおかし...
-
クエリ表示と、ADOで抽出したレ...
-
ある条件の最大値+1を初番する...
-
sqlで、600行あるテーブルを100...
-
複数テーブルのGROUP BY の使い...
-
insertを高速化させたい
-
PL/SQLの変数について
-
キー毎の、ある列のmaxのレコー...
おすすめ情報