草庐IT

php - 检查用户是否为帖子添加书签的更好方法

coder 2023-10-25 原文

我正在为网站做一个小书签功能,用户可以在其中为帖子添加书签。当用户为帖子添加书签时,它会添加到表 postMarks 中。

我目前的做法是从表 posts 中打印主要帖子,然后从表 postMarks 中打印 select count()每个 postId = iduserId = currentUser。有没有更好、更有效的方法来执行此操作,而不是运行两个单独的语句。我觉得我这样做的方式效率很低。

我所有的代码都在下面。由于这仍未实现,我可以进行更改。

帖子

"id"    "postTitle"
"1"     "Title 1"
"2"     "Title 2"
"3"     "Title 3"
"4"     "Title 4"
"5"     "Title 5"
"6"     "Title 6"
"7"     "Title 7"
"8"     "Title 8"
"9"     "Title 9"
"10"    "Title 10"

邮戳

"id"    "postId"    "postTitle" "userId"    "addDate"
"1"     "1"         "Title 1"   "1"         "2014-04-22 09:57:35"
"2"     "2"         "Title 2"   "1"         "2014-04-22 09:58:10"
"3"     "3"         "Title 3"   "1"         "2014-04-22 09:58:12"
"4"     "4"         "Title 4"   "1"         "2014-04-22 09:58:25"
"5"     "5"         "Title 5"   "1"         "2014-04-22 09:58:37"
"6"     "1"         "Title 1"   "2"         "2014-04-22 09:59:10"
"7"     "2"         "Title 2"   "2"         "2014-04-22 09:59:20"
"8"     "1"         "Title 1"   "3"         "2014-04-22 09:59:33"
"9"     "2"         "Title 2"   "3"         "2014-04-22 09:59:45"
"10"    "3"         "Title 3"   "3"         "2014-04-22 09:59:53"

我的代码

$userId = 1;

$pageData = 'select id, postTitle from posts LIMIT 10';

$stmt = $conn->prepare($pageData);

$stmt->execute();

$stmt->bindColumn(1,$a);
$stmt->bindColumn(2,$b);

$posts = $stmt->rowCount();

if($posts >= 1) {

    while($rows = $stmt->fetch(PDO::FETCH_BOUND)) {
        echo $a.' '.$b;

        // Bookmarks
        $bookMarks = "select count(postId) from postMarks where postId = '".$a."' and userId = '".$userId."'";

        $stmtx = $conn->prepare($bookMarks);

        $stmtx->execute();

        $stmtx->bindColumn(1,$a);

        $stmtx->fetch();

        if($a == 1) {
            echo ' Bookmarked <br>';
        } else {
            echo ' Not Bookmarked <br>';
        }           
        // Bookmarks detect ends
    }

} else {
    echo 'Nothing to display ';
}

结果

1 Title 1 Bookmarked
2 Title 2 Bookmarked
3 Title 3 Bookmarked
4 Title 4 Bookmarked
5 Title 5 Bookmarked
6 Title 6 Not Bookmarked
7 Title 7 Not Bookmarked
8 Title 8 Not Bookmarked
9 Title 9 Not Bookmarked
10 Title 10 Not Bookmarked 

最佳答案

我用连接更新了你的 sql 查询。如果当前用户为该页面添加了书签,您现在应该能够得到一个 bool 值。

$pageData = 'SELECT
                    id,
                    postTitle,
                    IF( count(distinct postMarks.userId) > 0, true, false) as bookmarkByUser
             FROM 
                    postsLEFT JOIN postMarks ON posts.id=postMarks.postId AND userId =".$userId."
             GROUP BY
                    post.idLIMIT 10';

关于php - 检查用户是否为帖子添加书签的更好方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23211298/

有关php - 检查用户是否为帖子添加书签的更好方法的更多相关文章

  1. ruby - 如何使用 Nokogiri 的 xpath 和 at_xpath 方法 - 2

    我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div

  2. ruby - 如何从 ruby​​ 中的字符串运行任意对象方法? - 2

    总的来说,我对ruby​​还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用

  3. ruby - 为什么我可以在 Ruby 中使用 Object#send 访问私有(private)/ protected 方法? - 2

    类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc

  4. ruby - Facter::Util::Uptime:Module 的未定义方法 get_uptime (NoMethodError) - 2

    我正在尝试设置一个puppet节点,但ruby​​gems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由ruby​​gems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby

  5. ruby - 我需要将 Bundler 本身添加到 Gemfile 中吗? - 2

    当我使用Bundler时,是否需要在我的Gemfile中将其列为依赖项?毕竟,我的代码中有些地方需要它。例如,当我进行Bundler设置时:require"bundler/setup" 最佳答案 没有。您可以尝试,但首先您必须用鞋带将自己抬离地面。 关于ruby-我需要将Bundler本身添加到Gemfile中吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/4758609/

  6. ruby-on-rails - 如何验证 update_all 是否实际在 Rails 中更新 - 2

    给定这段代码defcreate@upgrades=User.update_all(["role=?","upgraded"],:id=>params[:upgrade])redirect_toadmin_upgrades_path,:notice=>"Successfullyupgradeduser."end我如何在该操作中实际验证它们是否已保存或未重定向到适当的页面和消息? 最佳答案 在Rails3中,update_all不返回任何有意义的信息,除了已更新的记录数(这可能取决于您的DBMS是否返回该信息)。http://ar.ru

  7. Ruby 方法() 方法 - 2

    我想了解Ruby方法methods()是如何工作的。我尝试使用“ruby方法”在Google上搜索,但这不是我需要的。我也看过ruby​​-doc.org,但我没有找到这种方法。你能详细解释一下它是如何工作的或者给我一个链接吗?更新我用methods()方法做了实验,得到了这样的结果:'labrat'代码classFirstdeffirst_instance_mymethodenddefself.first_class_mymethodendendclassSecond使用类#returnsavailablemethodslistforclassandancestorsputsSeco

  8. ruby - 检查 "command"的输出应该包含 NilClass 的意外崩溃 - 2

    为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar

  9. ruby - 将 Bootstrap Less 添加到 Sinatra - 2

    我有一个ModularSinatra应用程序,我正在尝试将Bootstrap添加到应用程序中。get'/bootstrap/application.css'doless:"bootstrap/bootstrap"end我在views/bootstrap中有所有less文件,包括bootstrap.less。我收到这个错误:Less::ParseErrorat/bootstrap/application.css'reset.less'wasn'tfound.Bootstrap.less的第一行是://CSSReset@import"reset.less";我尝试了所有不同的路径格式,但它

  10. ruby-on-rails - Rails 3.2.1 中 ActionMailer 中的未定义方法 'default_content_type=' - 2

    我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer

随机推荐