質問編集履歴

1

質問の趣旨を明確化

2019/03/02 09:42

投稿

Take_it
Take_it

スコア357

test CHANGED
File without changes
test CHANGED
@@ -15,3 +15,49 @@
15
15
 
16
16
 
17
17
  文字列で扱わなければならない場合のみ、テーブルを分けるという方法もできなくはないのですが、その方が好ましいのでしょうか?
18
+
19
+
20
+
21
+ ===追記===
22
+
23
+ 質問の仕方が悪かったかもしれません。
24
+
25
+
26
+
27
+ 個人別データを記述したテーブルAには、所属する部署コードと適用される勤務シフトコードのカラムがあります。
28
+
29
+
30
+
31
+ 部署データは、INT UNSIGNED AI でコードを生成されたテーブルになります。
32
+
33
+
34
+
35
+ 勤務シフトデータは、部署データのコードをキーに設定したテーブルです。
36
+
37
+
38
+
39
+ つまり、部署ごとに勤務シフトが一応決まっていて、個人別データにおいて部署コードと勤務シフトコードのカラムの値は基本的には同一になる設計です。
40
+
41
+
42
+
43
+ ところが一部、所属する部署の勤務シフトとは異なる勤務シフトを設定した場合があり、これをどのように扱うかを検討する際に、
44
+
45
+ 勤務シフトデータのテーブルに、部署コードではなく従業員コードをキーに放り込んだデータを用意することとしましたが、当然ですがそれでは部署コードと従業員コードが重複する可能性が排除できません。
46
+
47
+ そこで、その場合は、なんらかの接頭辞_従業員コードをキーに放り込めば、重複を回避することができます。
48
+
49
+ 但しその場合、キーに使うカラムをINT型ではなくVAECHAR型にする必要があり・・・
50
+
51
+
52
+
53
+ という前提のもと、
54
+
55
+
56
+
57
+ ・VERCHAR型で作った場合と
58
+
59
+ ・(接頭辞をつけるようなデータは入れないように見直して)INT型で作った場合
60
+
61
+
62
+
63
+ パフォーマンスにおいて有意な差が出るかどうか、というのが質問です。