回答

收藏

用于sql表中“ tatus”列的类型

技术问答 技术问答 339 人阅读 | 0 人回复 | 2023-09-14

我有一个(虚拟)表结构,如下所示:, u5 X- v6 Q1 M) L
票证  **ID** :int(11)PK  **名称** :varchar(255)  **状态** ?????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????问题是,我应该使用哪种数据类型作为状态?正如我所看到的,这是我的选择:. [. W# Z8 |8 G  g. O
[ol]varchar代表状态-错误是因为没有完整性, W9 H& o  f; ?( ^. K* G
枚举代表状态-BAD,因为要改变值,我必须改变表,然后添加任何值下拉列表的代码,等等1 P9 T; R9 ?) b( ~3 D+ u
int FK到状态表-好的,因为是动态的,不好的,因为很难通过目视检查(这可能很有用)/ `+ o) b; v7 L3 t* l! X+ b; R9 N) r
varchar FK到状态表-好的,因为它是动态的,在检查中可见。坏的,因为密钥是有意义的,通常是不合理的owned。有趣的是,在这种情况下,状态表可能只有一列,这使它成为美化的枚举[/ol]我对情况有准确的了解吗?有意义的钥匙真的那么糟糕吗?因为虽然它确实给我带来了鸡皮b,但我没有任何理由这样做……
+ T! Y8 h  \" z) O& @8 ]& `更新:    对于选项4,建议的结构将是 status表的状态    : char(4)FK    。所以,+ c& [8 S( H3 `
OPEN =>“打开”
' ^: v" C# T8 p1 mCLOS =>“已关闭”( N7 \; L4 B1 B4 V& g1 J2 [/ R# C) D
“ PEND” =>待定授权! ~$ w7 N, J: g
“ PROG” =>“进行中
- R2 N4 [/ }2 i3 j& M在这种情况下有什么缺点?我可以看到在这种情况下使用它int而不是char唯一的优点是性能稍差。% O% L+ J% v" i  D! Q
                                                               
# z  l; ~+ V6 C    解决方案:                                                                9 W  w. W1 \- ]) E  y
                                                                转到数字3。如果您想检查某些内容,请在状态值中创建连接视图。
分享到:
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则