你认为在MySQL数据库的记录中存储几个图像id的更好的方法是什么?它只是图像id,它将用于从不同的库中获取图像。
我是像1#4#7#9#10#12那样在记录中内爆id,还是只是序列化数组并存储它?使用一种而不是另一种是否会带来性能上的好处?稳定性偏好?
我只是一直使用内爆和爆炸,从来没有真正考虑过它。谢谢。
发布于 2012-11-02 22:32:08
我建议使用序列化或JSON-encode。
它是更灵活的,例如,将允许您添加图片标题和其他细节在那里在未来…
发布于 2012-11-02 22:35:52
如果您不想(过度?)规范化您的表,并且您真的只想存储一个If列表,那么我建议使用一个简单的逗号分隔列表,因为MySQL已经有一些函数可以直接处理逗号分隔的字符串值:
FIND_IN_SET:http://dev.mysql.com/doc/refman/5.0/en/string-functions.html#function_find-in-set
SELECT FIND_IN_SET('b','a,b,c,d'); --> 2CONCAT_WS:http://dev.mysql.com/doc/refman/5.0/en/string-functions.html#function_concat-ws
SELECT CONCAT_WS(',','First name',NULL,'Last Name'); --> 'First name,Last Name'当然,您不能进行SQL连接,但它仍然可以提供帮助。
发布于 2012-11-02 22:33:11
据我所知,在这种情况下没有显着的区别,但implode()更快一些,因为它假设了一个数组,而serialize()不知道您传递给它的是什么。
根据OP的评论编辑:
,所有的图像都存储在一个单独的库表中,里面有标题和描述之类的东西。但我明白你的意思。
在这种情况下,不是一个好主意,所以将几个ID序列化为一个字段。您需要的是两个表之间的*对多关系。这是表示多值字段的正确方式:
+----------------------+
| USER |
+---------+------+-----+
| user_id | name | ... |
+---------+------+-----+
+----------------------+
| USER_PICTURE |
+---------+------------+
| user_id | picture_id |
+---------+------------+
+--------------------------+
| PICTURE |
+------------+-------+-----+
| picture_id | title | ... |
+------------+-------+-----+https://stackoverflow.com/questions/13197255
复制相似问题