欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

一个字段多个值的数据库设计问题

程序员文章站 2024-01-14 18:33:16
...
现在有字段A。取值是单个的,比如取值是3
有一个字段,取值是多个的。比如字段B,取值可能是1、2、3、4
现在要查出所有含有字段A的值的记录。比如:

记录1:3、5、7(符合)
记录2:6、8、9(不符合)

请问如何设计数据库比较合理?充分考虑到性能优化。

回复讨论(解决方案)

我好像想到方法了。
在数据库里面是这样保存B字段的数据的
|2|4|6|3|
如果我要查询是否含有3.就 like %|3|%。这样可行吗?

可以啊,或者用逗号隔开也行。

如果值域不超过64,那么可直接使用 set 类型
如果不想用 set 类型,值域也肯能远超过 64
那么可以用 varchar 或 text 类型
数据由以逗号分隔的串组成,比如 2,4,6,3
mysql 提供了 find_in_set 函数,用来完成查找工作

如果值域不超过64,那么可直接使用 set 类型
如果不想用 set 类型,值域也肯能远超过 64
那么可以用 varchar 或 text 类型
数据由以逗号分隔的串组成,比如 2,4,6,3
mysql 提供了 find_in_set 函数,用来完成查找工作

能说说最优方案吗?
值域很少。20个以下。值是固定的数组里面选出的。
现在比较在乎性能。假加上万条几十万,要找到匹配的数据,太慢了不行呀。

如果值域不超过64,那么可直接使用 set 类型
如果不想用 set 类型,值域也肯能远超过 64
那么可以用 varchar 或 text 类型
数据由以逗号分隔的串组成,比如 2,4,6,3
mysql 提供了 find_in_set 函数,用来完成查找工作

受教了。第一次懂得mysql字段还有set类型的。mysql还有find_in_set函数
两种方法都可以解决问题。有空我亲自测试一下哪个方法速度最快!

like 和 find_in_set 还有 in
都是在求“是否在其中”,性能肯定不会高到哪里去
把数据打包在一起,本身就是以时间换空间的做法

要想达到高速的目的,当然就不能打包在一起,而是独立存放并加上索引,当然还要加上宿主的id
这就是所谓的以空间换时间