一字段多值:数据库表如何存储? (数据库表一个字段中对应多个值)

2023年 8月 10日 82.5k 0

在数据库设计中,经常涉及到一个字段需要存储多个值的情况,比如一篇文章可能有多个标签,一个人可能有多个爱好等等。这时候就需要考虑如何在数据库表中存储这些多值字段。

1. 多值字段的存储方式

一般来说,有以下几种存储方式:

1.1. 重复字段

这种方式就是在同一个表中,为每个值都单独创建一个字段。比如,对于一个人的爱好字段,可以创建hobby1、hobby2、hobby3等多个字段。这种方式虽然简单,但是会导致表结构臃肿,而且如果需要频繁查询多值字段,效率也不高。

1.2. 多行记录

这种方式是把多值字段拆分成多个表行记录,每个记录只包含单个值。比如,对于一篇文章的标签字段,可以创建一个tags表,每个标签对应一行,文章和标签之间用中间表进行关联。这种方式可以避免数据冗余,但是操作复杂,需要使用联表查询才能获取完整的多值字段信息。

1.3. 分隔符

这种方式是把多个值用一个分隔符隔开,存储在单个字段中。比如,对于一个人的爱好字段,可以使用逗号隔开不同的爱好。这种方式简单易用,但是对于复杂数据类型不太适用,而且在查询和更新时需要使用字符串处理函数。

2. 多值字段的选择

在具体实现多值字段时,需要根据实际情况选择合适的存储方式。如果是对性能要求较高的多值字段,可以选择使用多行记录方式,而对于简单的多值字段,使用分隔符也可以达到较好的实现效果。

3. 多值字段的查询和更新

在使用多值字段时,需要注意查询和更新的操作。对于多行记录方式,需要使用联表查询才能获取完整的多值字段信息。而对于分隔符方式,需要使用字符串处理函数进行查询和更新操作。

4. 多值字段和规范化

多值字段的存储方式和规范化之间并不矛盾,可以在保证数据库表符合规范化的同时,选择合适的多值字段存储方式。比如,在2NF、3NF等规范化中仍然可以使用多行记录或分隔符方式实现多值字段。

5. 多值字段的使用场景

多值字段在实际应用中非常常见,比如标签、关键词、爱好等等。在设计数据库表结构时,需要考虑到这些场景,并选择合适的多值字段存储方式。

多值字段是数据库设计中常见的问题,正确选择存储方式,合理进行查询和更新操作,可以避免表结构臃肿、提高查询效率,实现良好的数据库设计体系。

相关问题拓展阅读:

  • mysql查询同一个字段必须满足多个值
  • sql如何根据一个字段的多个值查询
  • sql 一个表中字段存多个数字,对应到另一个表中的值,怎么得到另个表对应的值。

mysql查询同一个字段必须满足多个值

代码如下:

select

*

from

news_extinfo

where

(extid

=

and

optionvalue

=

0)

or

(extid

=

and

optionvalue

=

)

or

(extid

=

and

optionvalue

=

)

group

by

newsid

having

count(*)=3

此处

count(*)

=

表示亩余慧的意思是

在查询的结果毁派中,只查出按group

分组迅答之后,每个组的有3条数据的结果集

sql如何根据一个字段的多个值查询

select

别名.字段1,别名.字段2,别名.字段3

FROM

表.别名

WHERE

别名.字段1

IN

(‘字段1值1′,字段1值2”,’字段1值3’);

用关键字

IN实现

一个字段的多个值查询,上面使用伪代码举例

希望我的回答对你有帮助。。

如果menuid是列表1,5,8

那么select

distinct

companyid

from

menutable

where

menuid

in(‘1′,’5′,’8’)(如果menuid为字符类型,数字类型将引号去掉)

如果传入的menuid是个字符串1,5,8

那么写成select

distinct

companyid

from

menutable

where

‘,1,5,8,’

like

‘%,’+cast(menuid

as

varchar)+’,%’

select

companyid

from

表名

where

menuid

in

(值

,

,

……)

或者

menuid是根据别的条件从别的地方查出来的

select

companyid

from

表名

where

menuid

in

(select

menuid

from

…..)

sql 一个表中字段存多个数字,对应到另一个表中的值,怎么得到另个表对应的值。

CREATE  TABLE  t1 (

  Text  varchar(10)

);

INSERT INTO t1 VALUES(‘1,2’);

CREATE TABLE t2 (

  id  INT,

  Value  varchar(2)

);

INSERT INTO t2 VALUES(1, ‘A’);

INSERT INTO t2 VALUES(2, ‘B’);

SELECT 

  GROUP_CONCAT(t2.Value) 

FROM 

  t2, t1

WHERE 

  INSTR(CONCAT(‘,’,  t1.Text, ‘,’), CONCAT(‘,’, CAST(t2.id as char), ‘,’)) > 0;

++

| GROUP_CONCAT(t2.Value) |

++

| A,B      |

++

1 row in set (0.00 sec)

MySQL 下测试通过。

如果你是sql server的 话;方法如下

select 表2.* from 表2 where (charindex(表2.id , (select text from 表1))) 0

select 表2.* from 表1,表2 where 表1.text in(select id from 表2)

你测试下…

关于数据库表一个字段中对应多个值的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

相关文章

Oracle如何使用授予和撤销权限的语法和示例
Awesome Project: 探索 MatrixOrigin 云原生分布式数据库
下载丨66页PDF,云和恩墨技术通讯(2024年7月刊)
社区版oceanbase安装
Oracle 导出CSV工具-sqluldr2
ETL数据集成丨快速将MySQL数据迁移至Doris数据库

发布评论