PRIMARY KEYとしてVARCHARを使用することはできますか?
2023-09-30 12:18:23
質問
クーポン/割引を格納するテーブルがあり、coupon_codeカラムを主キーとして
VARCHAR
.
私の根拠は、各クーポンには固有のコードがあり、私が実行する唯一のコマンドは
SELECT ... FROM ... WHERE coupon_code='..'
結合やインデックスを作成することはありませんし、このテーブルに数百以上のエントリが存在することはないと思います。
これで大丈夫だと思うのですが、何か見落としていること、考えていないことがあるのでしょうか。
どのように解決するのですか?
もちろん、RDBMSがそれを可能にするという意味では、できます。という質問に対する回答は、以下のとおりです。 べきである ほとんどの場合、データベースシステムの外部で意味を持つ値は、 を使用すべきです。 ではない は主キーに選ばれるべきではありません。
その値がモデル化しているシステムで一意であることが分かっている場合、テーブルに一意インデックスや一意制約を追加することは適切です。しかし、主キーは一般的に、自動インクリメントの数値やGUIDなど、何らかのquot;meanice"値であるべきです。
データ入力エラーや、変更不可能に見えるものへの頻繁でない変更は、実際に起こります。これらは、主キーとして使用される値で修正することがより困難になります。
関連
-
MySQLのLike演算子に関する詳細
-
Mysql がエラー 1241 を報告 オペランドは 1 つのカラムを含む必要があります。
-
[解決済み] MySQLでdatetimeとtimestampのどちらのデータ型を使用すべきですか?
-
[解決済み] PHPでSQLインジェクションを防ぐにはどうしたらいいですか?
-
[解決済み] MySQLでコマンドラインを使用してSQLファイルをインポートするにはどうすればよいですか?
-
[解決済み] varcharとnvarcharの違いは何ですか?
-
[解決済み] MySQLで'insert if not exists'を行うにはどうしたらいいですか?
-
[解決済み] MySQLです。大きなVARCHARとTEXTの比較?
-
[解決済み] Sqliteの複数カラムの主キー
-
[解決済み】「INNER JOIN」と「OUTER JOIN」の違いは何ですか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
MySQLのLike演算子に関する詳細
-
MySQLデータベースでvarchar型の数値の大きさを比較する方法
-
SQL集計、グループ化、ソート
-
MySQLインデックスベースストレステストの実装
-
SpringBootのMySQLへの接続は、バックエンドのインターフェイスの操作方法を書き込むためのデータを取得するために
-
MySQLインストールチュートリアル(Linux版
-
[解決済み】ValueError: 値の長さがインデックスの長さと一致しない|Pandas DataFrame.unique()
-
sql エラーを解決する オペランドには1つの列が含まれている必要があります。
-
[解決済み] どのトランザクションが「テーブルメタデータのロック待ち」状態を引き起こしているかを確認するにはどうすればよいですか?
-
[解決済み] Mysqlでidを使用してテーブルから多くの行を削除する