我正在尝试为我的社交网络创建一个通知系统。但是我被数据库设计所困扰。因此,当一个用户对另一个用户发表评论时,我想显示“ X对您的信息发表了评论”。或当有人关注另一个人时,我想显示一个通知。
到目前为止,这是我的表:
CREATE TABLE IF NOT EXISTS `notifications` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`user_id` int(11) NOT NULL,
`notification_id` int(11) NOT NULL,
`text` text NOT NULL,
`read` int(11) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;
我最困惑的部分是,当有人关注另一个人时我应该插入记录吗?就像...有人点击“关注”按钮之后?如果是这样,我应该在行中插入什么?
我在Laravel框架中使用PHP。
参考方案
由于这是一个开放的问题,没有完美的解决方案,因此我建议采用以下结构:
Events table
id type text
-----------------------------------------------
1 comment commented on your post
2 follow followed you
etc
然后,通知表将如下所示(我想不出更好的字段名称来传达这个想法):
Notification table
id user_to_notify user_who_fired_event event_id seen_by_user
---------------------------------------------------------------------------
1 12 13 2 yes
2 13 12 1 no
3 1 15 1 yes
(seen_by_user可以是boolean)。
使用上述结构的优点是,您可以在不使用复杂的SQL查询的情况下回答以下查询:
1)用户Y对用户X的评论总数。
2)用户阅读或单击通知的方式。例如:他可能不会点击跟随他的人的通知。
3)如果某个用户偏爱不通知其某些事件的用户,则可以根据event_id将其过滤掉
因此,一旦X对Y的帖子发表评论,您就在通知表中创建了一个条目,然后在评论表中添加了这些评论。
希望这对您有所帮助!
Laravel 5错误报告抑制 - php
在Laravel 4中,抑制E_NOTICE消息很容易;我似乎无法做到这一点,因为如果我添加error_reporting(E_ALL ^ E_NOTICE) 它只是被覆盖的任何地方。这似乎发生在这里:(index.php)$response = $kernel->handle( $request = Illuminate\Http\Request::…PHP getallheaders替代 - php
我正在尝试从服务器上的apache切换到nginx。唯一的问题是我在PHP脚本中使用的getallheaders()函数,该函数不适用于Nginx。我已经尝试过用户在getallheaders函数上的php站点上提供的注释,但这并不返回所有请求标头。请告诉我如何解决这个问题。我真的想切换到Nginx。 参考方案 您仍然可以使用它,但是您必须像这里一样重新定义…php Singleton类实例将在多个会话中保留吗? - php
举一个简单的例子,如果我想计算一个不使用磁盘存储的脚本的命中次数,我可以使用静态类成员来执行此操作吗?用户1:<?php $test = Example::singleton(); $test->visits++; ?> 用户2:<?php $test = Example::singleton(); $test->visits+…PHP:将字符串拆分为字母和数字部分的最佳方法 - php
我有几个格式的字符串AA11 AAAAAA1111111 AA1111111 分离字符串的字母和数字部分的最佳方法(最有效)? 参考方案 如果它们都是一系列字母,然后是一系列数字,并且没有非字母数字字符,那么sscanf()可能比regexp更有效$example = 'AAA11111'; list($alpha,$numeric) =…php-casperjs获取内部文本 - php
我正在为casperjs使用php包装器-https://github.com/alwex/php-casperjs我正在网上自动化一些重复的工作,我需要访问一个项目的innerText,但是我尚不清楚如何从casperjs浏览器访问dom。我认为在js中我会var arr = document.querySelector('label.input…