快速总结:我有一个社交网站,用户可以在其中关注/发布/投票等。我正在为每个用户的个人资料添加一个新的类似 facebook 的事件墙功能。
我已经在这方面工作了几天,但似乎无法让它正常工作。我想要的是,就像我提到的 facebook 墙一样......当访问者访问用户的个人资料时,该用户的事件将显示,无论他们最近对帖子“投票”,评论还是发布了他们自己的东西,我希望它显示在他们的个人资料中,当然,将最新的条目放在最上面。
我现在遇到的问题是:有些东西显示了两次,而且没有按最近的排序。
我在这里使用 3 个表(我只发布了我正在使用的列):
Table structure for table votes_posts
Field Type Null Default
indexer int(11) No
post_id int(11) No
vote int(11) No
user_name varchar(250) No
date varchar(255) No
Table structure for table posts
Field Type Null Default
id int(11) No
name varchar(30) No
content text No
datetimerss varchar(255) No
category int(11) No
Table structure for table comments
Field Type Null Default
id int(12) No
post_id int(12) No
name varchar(30) No
content text No
type varchar(30) No
datetimerss varchar(255) No
$users 就是 $_GET['user'] timeAgo() 函数,简单地显示非常流行的“xx 前发布”日期时间。
<ul class="streamActivity">
<?php
$checkActivity = "SELECT votes_posts.post_id, votes_posts.user_name, votes_posts.vote, votes_posts.date,
posts.id, posts.content, posts.name, posts.datetimerss, categories.category,
comments.post_id AS comm_postid, comments.content AS comm_content, comments.name AS comm_name, comments.datetimerss AS comm_date, comments.type
FROM `votes_posts`
LEFT OUTER JOIN `posts` ON votes_posts.post_id = posts.id
LEFT OUTER JOIN `comments` ON posts.id = comments.post_id
LEFT OUTER JOIN `categories` ON posts.category = categories.cat_id
WHERE (votes_posts.post_id = posts.id AND user_name = '$user')
OR (comments.post_id = posts.id AND comments.name = '$user')
OR (posts.name = '$user') ORDER BY votes_posts.date, posts.datetimerss, comments.datetimerss ASC";
$checkActivityResult = mysql_query($checkActivity);
if (mysql_num_rows($checkActivityResult) > 0) {
while ($sessionAct = mysql_fetch_array($checkActivityResult)) {
$category = strtolower($sessionAct['category']);
$dateVote = timeAgo($sessionAct['date']);
$datePost = timeAgo($sessionAct['datetimerss']);
$dateComm = timeAgo($sessionAct['comm_date']);
$namePost = $sessionAct['name'];
$nameComm = $sessionAct['comm_name'];
$nameVote = $sessionAct['user_name'];
$idVote = $sessionAct['post_id'];
$idPost = $sessionAct['id'];
$idComm = $sessionAct['comm_postid'];
$contentPost = $sessionAct['content'];
$contentComm = $sessionAct['comm_content'];
$typeComm = $sessionAct['type'];
if ($namePost == $user) {
$classList = 'storyPost';
$classIcon = 'iconMuttr';
$name = $namePost;
$content = $contentPost .' ... read more';
$datetime = $datePost;
}
elseif ($nameComm == $user && $typeComm == "Comment") {
$classList = 'actionPost';
$classIcon = 'iconComment';
$name = $nameComm;
$content = 'Commented "'. $contentComm .'"';
$datetime = $dateComm;
} elseif ($nameComm == $user && $typeComm == "Advice") {
$classList = 'actionPost';
$classIcon = 'iconAdvice';
$name = $nameComm;
$content = 'gave Advice "'. $contentComm .'"';
$datetime = $dateComm;
}
elseif ($nameVote == $user) {
if ($sessionAct['vote'] == "1") {
$classList = 'actionPost';
$classIcon = 'iconLaughed';
$name = $nameVote;
$content = 'Laughed at "'. $contentPost .'"';
$datetime = $dateVote;
} elseif ($sessionAct['vote'] == "2") {
$classList = 'actionPost';
$classIcon = 'iconLoved';
$name = $nameVote;
$content = 'Showed Love on "'. $contentPost .'"';
$datetime = $dateVote;
} elseif ($sessionAct['vote'] == "3") {
$classList = 'actionPost';
$classIcon = 'iconIdiot';
$name = $nameVote;
$content = 'called '. $namePost .' an Idiot for "'. $contentPost .'"';
$datetime = $dateVote;
}
}
?>
<li class="row-activity <?php echo $classList; ?>">
<a href="" class="avatar"><img src="/images/avatars/default_male.jpg" /></a>
<div class="info">
<div class="userName">
<a href=""><?php echo $name; ?></a>
</div>
<span class="msgBody"><?php echo $content; ?></span>
<div class="imgTimeStream">
<span class="img <?php echo $classIcon; ?>"></span>
<span class="source"><?php echo $datetime; ?></span>
</div>
</div>
</li>
<?php
}
} else {
echo '<p>This user has no recent activity.</p>';
}
?>
</ul>
我绝不是专家级程序员...我所知道的一切都是在过去一两年里自学的,所以我只能想象这真的有多丑陋,哈哈。不过,我每天都在学习,我希望继续 :)
此外,在每种类型的事件中,某些内容的 CSS 类会略有不同。 例子: 如果结果行是一篇文章,那么列表项的 css 类将是“post” 如果结果行是投票,则列表项的 css 类将是“投票” 等等
如有任何帮助,我们将不胜感激!
更新:好吧,多个查询似乎工作正常......不再重复。我什至让它只显示最近几个月的事件(无论如何现在)。现在我需要弄清楚如何混合结果,所以最近的结果(无论是投票还是帖子等)都在顶部。
附言我可能应该提到很多数据将通过它传递(想想 facebook 墙+twitter feed 哈哈)
最佳答案
您应该将您的查询变成 3 个语句(投票、帖子、评论)的并集,它们返回相同的列集。您的查询中发生的情况是多个投票、帖子或评论乘以查询生成的行。
顺便说一句,如果可能,您应该转换为使用参数化 SQL,以消除潜在的 SQL 注入(inject)漏洞。
关于php - 多表JOIN返回重复结果,类似facebook的事件墙,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5609998/
为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返
我有一个包含多个键的散列和一个字符串,该字符串不包含散列中的任何键或包含一个键。h={"k1"=>"v1","k2"=>"v2","k3"=>"v3"}s="thisisanexamplestringthatmightoccurwithakeysomewhereinthestringk1(withspecialcharacterslike(^&*$#@!^&&*))"检查s是否包含h中的任何键的最佳方法是什么,如果包含,则返回它包含的键的值?例如,对于上面的h和s的例子,输出应该是v1。编辑:只有字符串是用户定义的。哈希将始终相同。 最佳答案
我有一个rubyonrails应用程序。我按照facebook的说明添加了一个像素。但是,要跟踪转化,Facebook要求您将页面置于达到预期结果时出现的转化中。即,如果我想显示客户已注册,我会将您注册后转到的页面作为成功对象进行跟踪。我的问题是,当客户注册时,在我的应用程序中没有登陆页面。该应用程序将用户带回主页。它在主页上显示了一条消息,所以我想看看是否有一种方法可以跟踪来自Controller操作而不是实际页面的转化。我需要计数的Action没有页面,它们是ControllerAction。是否有任何人都知道的关于如何执行此操作的gem、文档或最佳实践?这是进入布局文件的像素
所以我开始关注ruby,很多东西看起来不错,但我对隐式return语句很反感。我理解默认情况下让所有内容返回self或nil但不是语句的最后一个值。对我来说,它看起来非常脆弱(尤其是)如果你正在使用一个不打算返回某些东西的方法(尤其是一个改变状态/破坏性方法的函数!),其他人可能最终依赖于一个返回对方法的目的并不重要,并且有很大的改变机会。隐式返回有什么意义?有没有办法让事情变得更简单?总是有返回以防止隐含返回被认为是好的做法吗?我是不是太担心这个了?附言当人们想要从方法中返回特定的东西时,他们是否经常使用隐式返回,这不是让你组中的其他人更容易破坏彼此的代码吗?当然,记录一切并给出
为什么以下不同?Time.now.end_of_day==Time.now.end_of_day-0.days#falseTime.now.end_of_day.to_s==Time.now.end_of_day-0.days.to_s#true 最佳答案 因为纳秒数不同:ruby-1.9.2-p180:014>(Time.now.end_of_day-0.days).nsec=>999999000ruby-1.9.2-p180:015>Time.now.end_of_day.nsec=>999999998
在Ruby1.9.3(可能还有更早的版本,不确定)中,我试图弄清楚为什么Ruby的String#split方法会给我某些结果。我得到的结果似乎与我的预期相反。这是一个例子:"abcabc".split("b")#=>["a","ca","c"]"abcabc".split("a")#=>["","bc","bc"]"abcabc".split("c")#=>["ab","ab"]在这里,第一个示例返回的正是我所期望的。但在第二个示例中,我很困惑为什么#split返回零长度字符串作为返回数组的第一个值。这是什么原因呢?这是我所期望的:"abcabc".split("a")#=>["bc"
是否有简单的方法来更改默认ISO格式(yyyy-mm-dd)的ActiveAdmin日期过滤器显示格式? 最佳答案 您可以像这样为日期选择器提供额外的选项,而不是覆盖js:=f.input:my_date,as::datepicker,datepicker_options:{dateFormat:"mm/dd/yy"} 关于ruby-on-rails-事件管理员日期过滤器日期格式自定义,我们在StackOverflow上找到一个类似的问题: https://s
导读语言模型给我们的生产生活带来了极大便利,但同时不少人也利用他们从事作弊工作。如何规避这些难辨真伪的文字所产生的负面影响也成为一大难题。在3月9日智源Live第33期活动「DetectGPT:判断文本是否为机器生成的工具」中,主讲人Eric为我们讲解了DetectGPT工作背后的思路——一种基于概率曲率检测的用于检测模型生成文本的工具,它可以帮助我们更好地分辨文章的来源和可信度,对保护信息真实、防止欺诈等方面具有重要意义。本次报告主要围绕其功能,实现和效果等展开。(文末点击“阅读原文”,查看活动回放。)Ericmitchell斯坦福大学计算机系四年级博士生,由ChelseaFinn和Chri
我正在尝试将以下SQL查询转换为ActiveRecord,它正在融化我的大脑。deletefromtablewhereid有什么想法吗?我想做的是限制表中的行数。所以,我想删除少于最近10个条目的所有内容。编辑:通过结合以下几个答案找到了解决方案。Temperature.where('id这给我留下了最新的10个条目。 最佳答案 从您的SQL来看,您似乎想要从表中删除前10条记录。我相信到目前为止的大多数答案都会如此。这里有两个额外的选择:基于MurifoX的版本:Table.where(:id=>Table.order(:id).
我一直在研究RubyKoans,我发现about_open_classes.rbkoan很有趣。特别是他们修改Integer#even?方法的最后一个测试。我想尝试一下这个概念,所以我打开了Irb并尝试运行Integer.respond_to?(:even?),但令我惊讶的是我得到了错误。然后我尝试了Fixnum.respond_to?(:even?)并得到了错误。我还尝试了Integer.respond_to?(:respond_to?)并得到了true,当我执行2.even?时,我也得到了true。我不知道发生了什么。谁能告诉我缺少什么? 最佳答案