大家是怎么处理类型和类型描述的?

2017-03-03 08:58:18 +08:00
 rason
比如一个实体类 User ,有个性别属性, 1 表示男, 0 表示女。前端显示时,当然是显示文字,请问大家是在哪一层转换的。因为有太多的实体需要将数据库中保存的类型转成描述了。
3092 次点击
所在节点    Java
24 条回复
MiguelValentine
2017-03-03 09:10:22 +08:00
(!sex)?"女":"男";
前端啊。
JamesRuan
2017-03-03 09:13:24 +08:00
变量名为 is_man ,在视图层转换。
变量名是 gender ,则应该直接把文字保存在数据库。
如果变量名是 gender ,还存 0 和 1 ,应该把设计数据库的人抓出来打一顿(逃
fwrq41251
2017-03-03 09:14:07 +08:00
jpa AttributeConverter ,业务代码里应该只有枚举,没有 0,1 啥的
340244120
2017-03-03 09:14:49 +08:00
方案一 数据在显示层之前做转换,枚举比较多的话,可以用工具类进行转换。
方案二 显示层处理。缺点是前端工作量更多。优点是数据传输量相对少;前端快速实现多国语言切换等
rason
2017-03-03 09:27:26 +08:00
@MiguelValentine 要转换的地方太多的话会累死前端,而且还得沟通告诉前端啥对应啥。
rason
2017-03-03 09:29:07 +08:00
@340244120 多一个实体需要转换需要修改工具类,感觉挺麻烦的,我想要的效果是能够轻松统一处理多处的转换。
rason
2017-03-03 09:30:31 +08:00
@JamesRuan 直接数据库保存文字是一个好的方案?这个我不太确定,不知道大家是怎样用的。
JamesRuan
2017-03-03 09:37:02 +08:00
@rason 多国语言支持可以存专门的翻译用表,至少我知道 EVE 的数据库是这么设计的。

关键点在于,**别把 0->女 1->男这样的数据关系不当数据**。既然是数据,存数据库自然是最直接的。

说优化传输量的可以省省了,这明明是“过早优化”,减少传输数据量一个 gzip 就能搞定。

说优化储存量的,你要不用 is_man 这样的变量名,存 boolean ,要不就老老实实存字符类型。说不定哪天有个需求要求支持男女外的其他性别呢?( facebook ?)
shakespaces
2017-03-03 09:47:37 +08:00
一般来说给前端吧
MiguelValentine
2017-03-03 09:47:39 +08:00
@rason 关键前端在设置性别的时候,肯定传 0/1 吧。你们的业务不会传回来男女吧。刚好前端双绑定。
kanezeng
2017-03-03 09:52:33 +08:00
看情况吧,某些极端情况下,为了灵活调整,在数据库里建一个专门的对应表也可以吧。
以性别为例(当然这个不是特别极端,所以不是很合适,看看意思就好),比如建个性别表,有 id ,有描述,里面可以随时添加,比如:男,女,不男不女,变性,保密。。。。。。
用户表就存性别 id 就好了,传给前端的用户数据可以有 id ,也可以附带一项比如 gender_desc 把对应的描述加上啊。
rason
2017-03-03 10:01:13 +08:00
@MiguelValentine 嗯,这样做就是把锅丢给前端来玩了,所以想看看大家有没有什么好的解决方法。
rason
2017-03-03 10:02:16 +08:00
@kanezeng 恩,你说的方式我在工作中都有见过或者用到过,但是总感觉有点不足,所以想问问大家有什么更好的方式。
R18
2017-03-03 10:06:03 +08:00
前端
moguiyu
2017-03-03 10:36:16 +08:00
你这个举例,要是在某国,肯定会被一大波政治正确的多性别人士挑战,笑
zk123
2017-03-03 10:50:52 +08:00
## 为啥不直接在 user 中存男女
otakustay
2017-03-03 13:02:42 +08:00
前端转换,我的原则永远是面向用户的转换就在最靠近用户的层,如果前端还有 MVC 分层,那么就在 V 转换,这是架构的原则而不是丢锅,我作为前端只会尽量把这种转换的工作往自己这边揽,相比之后的沟通更新升级要省力多了
前端里实现枚举这样的结构用于做这些转换
QAPTEAWH
2017-03-03 13:05:34 +08:00
不好好用个 enum 表示用什么 0/1...

当然 0/1 挺形象的(逃
willakira
2017-03-03 13:52:34 +08:00
Gender 用 enum 最好 即便不是为了政治正确 也要考虑一下有人不想披露自己性别

至少有男 女 不详

一般我会在写到数据库的前一层(包着数据库的服务那块)才转换
好处是
- 数据库对于服务来说是透明的
- 每个数据库自己有自己的 db service 管编码解码
joysir
2017-03-03 14:04:51 +08:00
在使用 jsp 时,我会在实体定义一个变量: gengerName , getter 里面 做转换。然后页面直接使用。
如果是接口,则直接返回 0/1 , 很形象

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/344509

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX