一个普通的点赞功能,就是统计累加的次数,数据库字段很简单,一个unsigned int即可,问题是如何记录点赞的人。
不知道用字符串记录点赞的人的id可不可以?比如"1, 5, 169, 4214"
表示四个不同的id的用户点了赞。
问题是判断某个是否已经点赞,该怎么判? 比如
id=1
的用户有没有点赞,用字符串比较还是用in_array()
?如果似乎字符串比较,复杂度是
O(n)
吧?in_array()
的复杂度是O(n)还是O(log n)?数据库设计时,该字段用
varchar
还是text
?
回复内容:
一个普通的点赞功能,就是统计累加的次数,数据库字段很简单,一个unsigned int即可,问题是如何记录点赞的人。
不知道用字符串记录点赞的人的id可不可以?比如"1, 5, 169, 4214"
表示四个不同的id的用户点了赞。
问题是判断某个是否已经点赞,该怎么判? 比如
id=1
的用户有没有点赞,用字符串比较还是用in_array()
?如果似乎字符串比较,复杂度是
O(n)
吧?in_array()
的复杂度是O(n)还是O(log n)?数据库设计时,该字段用
varchar
还是text
?
一个点赞表
article_id,user_id
这样,每次统计文章的次数即可,article_id,user_id联合做主键也可以做到唯一性。
个人感觉不好,比较的逻辑过于复杂。
这种东西应该是 nosql 的强项,但非要用 mysql 做的话,我想到一种办法: