首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >序列化与内爆

序列化与内爆
EN

Stack Overflow用户
提问于 2012-11-02 22:30:09
回答 4查看 1.9K关注 0票数 2

你认为在MySQL数据库的记录中存储几个图像id的更好的方法是什么?它只是图像id,它将用于从不同的库中获取图像。

我是像1#4#7#9#10#12那样在记录中内爆id,还是只是序列化数组并存储它?使用一种而不是另一种是否会带来性能上的好处?稳定性偏好?

我只是一直使用内爆和爆炸,从来没有真正考虑过它。谢谢。

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2012-11-02 22:32:08

我建议使用序列化或JSON-encode。

它是更灵活的,例如,将允许您添加图片标题和其他细节在那里在未来…

票数 2
EN

Stack Overflow用户

发布于 2012-11-02 22:35:52

如果您不想(过度?)规范化您的表,并且您真的只想存储一个If列表,那么我建议使用一个简单的逗号分隔列表,因为MySQL已经有一些函数可以直接处理逗号分隔的字符串值:

FIND_IN_SEThttp://dev.mysql.com/doc/refman/5.0/en/string-functions.html#function_find-in-set

代码语言:javascript
复制
SELECT FIND_IN_SET('b','a,b,c,d'); --> 2

CONCAT_WShttp://dev.mysql.com/doc/refman/5.0/en/string-functions.html#function_concat-ws

代码语言:javascript
复制
SELECT CONCAT_WS(',','First name',NULL,'Last Name'); --> 'First name,Last Name'

当然,您不能进行SQL连接,但它仍然可以提供帮助。

票数 7
EN

Stack Overflow用户

发布于 2012-11-02 22:33:11

据我所知,在这种情况下没有显着的区别,但implode()更快一些,因为它假设了一个数组,而serialize()不知道您传递给它的是什么。

根据OP的评论编辑

,所有的图像都存储在一个单独的库表中,里面有标题和描述之类的东西。但我明白你的意思。

在这种情况下,不是一个好主意,所以将几个ID序列化为一个字段。您需要的是两个表之间的*对多关系。这是表示多值字段的正确方式:

代码语言:javascript
复制
+----------------------+
|  USER                |
+---------+------+-----+
| user_id | name | ... |
+---------+------+-----+

+----------------------+
|  USER_PICTURE        |
+---------+------------+
| user_id | picture_id |
+---------+------------+

+--------------------------+
|  PICTURE                 |
+------------+-------+-----+
| picture_id | title | ... |
+------------+-------+-----+
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13197255

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档