我有一个博客程序(类似Twitter),我目前正在制作一个最近访问的框,其中包含最近访问过您的页面的9个人。什么是存储和显示最近访问他人页面的人最有效的数据库方式?
每个人都使用不同的用户名注册。
什么我目前得到的是这样的数据库:
:-----------------------------
| id | username | who_visit |
-----------------------------
例如,如果9个用户foo1
到foo9
访问foo10
的页面,该数据库将与行填充
------------------------------------------------------------------------
| id | username | who_visit |
------------------------------------------------------------------------
| 1 | foo10 | foo1, foo2, foo3, foo4, foo5, foo6, foo7, foo8, foo9 |
------------------------------------------------------------------------
然后当foo11
访问foo10
的页面,我会从字符串的结尾去掉foo9
,并添加foo11
前面。
但现在的主要问题是,如果foo1
访问foo10
的页面,然后foo2
参观foo10
的页面,然后foo1
再次访问foo10
的页面?然后,我将不得不搜索9个用户,删除任何重复项,将其放在前面,然后继续执行。但问题是,那么它只会显示8行。
唯一的解决这个问题,我能想到的是使数据库这样的:
-----------------------------
| id | username | who_visit |
-----------------------------
而不是在一排填充它们,我想补充一个新的行为每一位光临:
-----------------------------
| id | username | who_visit |
-----------------------------
| 1 | foo10 | foo1 |
-----------------------------
| 2 | foo10 | foo2 |
-----------------------------
| 3 | foo10 | foo3 |
-----------------------------
| 4 | foo10 | foo4 |
-----------------------------
| 5 | foo10 | foo5 |
-----------------------------
| 6 | foo10 | foo6 |
-----------------------------
| 7 | foo10 | foo7 |
-----------------------------
| 8 | foo10 | foo8 |
-----------------------------
| 9 | foo10 | foo9 |
-----------------------------
但是这样会占用大量不必要的空间。
有没有一种方法我错过了,它可以有效地解决这个问题,而不需要为数据库中的一个用户添加> 50000行?
更新:对于那些具有相同问题的人,如下面在注释中所述的PM 77-1,可以在插入新行时删除最早的重复行。这样,你不会得到'数据膨胀'。
如何分割的逻辑:如果访问者已经在列表上,则代替他/她最早 – 2013-03-10 00:29:51
@ PM77-1哎,为什么我没有想到这一点。 – think123 2013-03-10 00:30:44
我将它扩展为答案。 – 2013-03-10 00:37:08