通知表设计? - php

我正在尝试为我的社交网络创建一个通知系统。但是我被数据库设计所困扰。因此,当一个用户对另一个用户发表评论时,我想显示“ 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…