用 type 作为数据表的字段名,会有什么隐患和冲突吗?

2018-04-23 10:53:20 +08:00
 miniyao
在 SQL 语句里 TYPE 是关键字,Python 语言里面 type()也是内置函数,在 MySQL 数据库里,商品类型的字段名用 type 作为列名,以后会有什么隐患和冲突吗?
4547 次点击
所在节点    Python
17 条回复
whx20202
2018-04-23 11:01:46 +08:00
sqlalchemy 里面映射的时候,给这个字段特别指定一下别名就行了
python 的层面也有办法处理

问题是你就不能用 item_type 吗
noqwerty
2018-04-23 11:15:57 +08:00
这种明知道会有隐患的命名还是换一个好吧。之前有一次 debug 一下午发现表里有一列的 index 是 sample,一直不能返回正确结果…
w7938940
2018-04-23 11:22:45 +08:00
在 Rails 里面 item_type 会被认为是多态
orangeade
2018-04-23 11:24:26 +08:00
type 还好,如果你用 order 做表名的话,还得用反引号
hebwjb
2018-04-23 11:24:50 +08:00
可以做映射
michaelcheng
2018-04-23 11:27:52 +08:00
隐形中有了重构的需求
vipppppp
2018-04-23 11:54:53 +08:00
为什么不用 category..
night98
2018-04-23 12:20:02 +08:00
表名首字母_type 这样会比较 OK
lozzow
2018-04-23 12:50:05 +08:00
我写 typo
ox180
2018-04-23 13:16:59 +08:00
type_
Livid
2018-04-23 13:17:44 +08:00
所以我用 kind 这个词。
wspsxing
2018-04-23 13:22:20 +08:00
typo 路过
miniyao
2018-04-23 13:38:50 +08:00
谢谢大家的建议,是接手的一个项目中有用 type 作商品分类的列名,虽然当前没什么问题,隐约有种不详之照,不想在以后出现莫名的坑,就想更改个命名,类型这个词呢 type 当然是最佳选择,不想造字的话,就选 category 和 kind 吧
turan12
2018-04-23 13:59:16 +08:00
@vipppppp 同用 category,握手。
yanze0613
2018-04-23 17:33:06 +08:00
数据库对列名和表名有个明确的设定叫保留字
官网有表,尽量别用,不然麻烦
bomb77
2018-04-24 10:35:57 +08:00
如一楼所说,sqlalchemy 映射的时候得用别名声明一下,看着有点变扭外,没遇到其他坑
如果可以,还是在数据库设计的时候就尽量不要用关键字命名吧
crist
2018-07-05 10:21:39 +08:00
typle 路过

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

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

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

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

© 2021 V2EX