我有两张表,一张存文章内容,一张存文章评论
我用来显示这些的函数是:
function list_articles() {
include('core/db/db_connection.php');
$sql = "SELECT blog.content_id, blog.title, blog.content, blog.posted_by, blog.date, article_comments.comments, article_comments.comment_by
FROM blog LEFT OUTER JOIN article_comments
ON blog.content_id = article_comments.blog_id
WHERE blog.content != ''
ORDER BY blog.content_id DESC";
$result = mysqli_query($dbCon, $sql);
$previous_blog_id = 0;
while ($row = mysqli_fetch_array($result)) {
if ($previous_blog_id != $row['content_id']) {
echo "<h5 class='posted_by'>Posted by {$row['posted_by']} on {$row['date']}</h5>
<h1 class='content_headers'>{$row['title']}</h1>
<article>{$row['content']}</article>
<hr class='artline'>";
$previous_blog_id = $row['content_id'];
}
if (!empty($row['comment_by']) && !empty($row['comments'])) {
echo "<div class='commented_by'>Posted by: {$row['comment_by']} </div>
<div class='comments'>Comments: {$row['comments']}</div>
<hr class='artline2'>";
}
}
}
我使用下面的代码将评论插入到 article_comments 表中:
function insert_comments($comments, $comment_by, $blog_id) {
include('core/db/db_connection.php');
$comment_by = sanitize($comment_by);
$comments = sanitize($comments);
$sql = "INSERT INTO article_comments (comments, comment_by, blog_id)
VALUES ('$comments', '$comment_by', '$blog_id')";
mysqli_query($dbCon, $sql);
}
这行得通 - 它执行插入,但是我不知道如何在用户提交帖子时定位 $blog_id 变量...下面是我使用的表单
<?php echo list_articles();
if (!empty($_POST)) {
insert_comments($_POST['comments'], $_POST['username'], 11);
}
?>
<form method='post' action='' class='comments_form'>
<input type='text' name='username' placeholder='your name... *' id='name'>
<textarea name='comments' id='textarea' placeholder='your comment... *' cols='30' rows='6'></textarea>
<input type='submit' name='submit' id='post' value='post'>
</form>
我打赌你注意到我手动插入了 11 作为最后一个变量的参数。这链接到我的 article_comments 表中的 blog_id 11(外键)。它正在正常显示评论。
有什么方法可以定位 $blog_id 而无需手动插入数字吗?类似于我如何使用 $_POST['comments'] 定位 $comments 变量?
此外,即使我可以定位,我怎么知道用户评论的是哪个帖子?我应该让他们在下拉列表中选择吗?这看起来很尴尬..但这是我能想到的唯一解决方案。
编辑:我尝试在隐藏字段中定位 blog_id:
function list_articles() {
include('core/db/db_connection.php');
$sql = "SELECT blog.content_id, blog.title, blog.content, blog.posted_by, blog.date, article_comments.comments, article_comments.comment_by
FROM blog LEFT OUTER JOIN article_comments
ON blog.content_id = article_comments.blog_id
WHERE blog.content != ''
ORDER BY blog.content_id DESC";
$result = mysqli_query($dbCon, $sql);
$previous_blog_id = 0;
while ($row = mysqli_fetch_array($result)) {
if ($previous_blog_id != $row['content_id']) {
echo "<h5 class='posted_by'>Posted by {$row['posted_by']} on {$row['date']}</h5>
<h1 class='content_headers'>{$row['title']}</h1>
<article>{$row['content']}</article>
<hr class='artline'>";
$previous_blog_id = $row['content_id'];
}
if (!empty($row['comment_by']) && !empty($row['comments'])) {
echo "<div class='commented_by'>Posted by: {$row['comment_by']} </div>
<div class='comments'>Comment: {$row['comments']}</div>
<hr class='artline2'>";
}
$sql2 = "SELECT FROM article_comments VALUES blog_id";
$result2 = mysqli_query($dbCon, $sql2);
while ($row = mysqli_fetch_assoc($result2)) {
echo " <form method='post' action='' class='comments_form'>
<input type='text' name='username' placeholder='your name... *' id='name'>
<textarea name='comments' id='textarea' placeholder='your comment... *' cols='30' rows='6'></textarea>
<input type='hidden' name=blog_id' value='{$row['blog_id']}'>
<input type='submit' name='submit' id='post' value='post'>
</form>";
}
}
}
sql2 和 result2 部分是导致错误的语句
编辑 2:
我认为 $sql2 不是正确的方法。代码现在可以正常工作,但我回到第 1 个方 block 。对于每条评论,插入的文章都会重复。
<form method='post' action='' class='comments_form'>
<input type='text' name='username' placeholder='your name... *' id='name'>
<textarea name='comments' id='textarea' placeholder='your comment... *' cols='30' rows='6'></textarea>
<input type='hidden' name=blog_id' value='{$row['blog_id']}'>
<input type='submit' name='submit' id='post' value='post'>
</form>";
有什么方法可以在不调用 while ($row = mysqli_fetch_array($result)) {} 的情况下定位 blog_id 吗?或者至少,不在第二个 while 循环中调用它?
我发布的第一段代码得到以下结果:
Article title: LOREM IPSUM
Content: LOREM IPSUM DOLOR SIT AMET....
--------------------------------------
Name: DSK
Comment: Great article!
--------------------------------------
Name: DSK
Comment: Great article! - 2nd comment
-- BEGIN SECOND ARTICLE ON WEBPAGE
Article title: LOREM IPSUM 2nd article
Content: LOREM IPSUM DOLOR SIT AMET....
--------------------------------------
Name: User0
Comment: Great article!
--------------------------------------
Name: User1
Comment: Great article! - 2nd comment
--------------------------------------
Name: User2
Comment: Great article! - 3rd comment
--------------------------------------
这正是我要找的。但是我只能通过 phpmyadmin 界面插入评论,手动选择外键(blog_id)。
我希望能够通过表单获得相同的结果:
Article title: LOREM IPSUM
Content: LOREM IPSUM DOLOR SIT AMET....
-------------------------------------- //comments
Name: DSK
Comment: Great article!
--------------------------------------
Name: DSK
Comment: Great article! - 2nd comment
-------------------------------------- // end comments
|-------------------------------------| // comments form
|Name: New User |
|Comment: New comment ! |
| |
|-------------------------------------|
[Submit]
当用户提交表单时,他的姓名和评论将被提交到数据库的 article_comments 表中。此外,外键 (blog_id) 应链接到现有文章(确实如此)。我只需要一种在我的函数中定位它的方法。
这有什么意义吗?......
最佳答案
也许您可以在表单中使用隐藏的表单元素:
<input type="hidden" name="blog_id" value="<?PHP echo $id;?>">
然后在提交时您可以使用 $_POST["blog_id"] 访问它
如果我正确理解你的问题,那就是。
关于php - 识别和连接表之间的 ID,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32025777/
我构建了两个需要相互通信和发送文件的Rails应用程序。例如,一个Rails应用程序会发送请求以查看其他应用程序数据库中的表。然后另一个应用程序将呈现该表的json并将其发回。我还希望一个应用程序将存储在其公共(public)目录中的文本文件发送到另一个应用程序的公共(public)目录。我从来没有做过这样的事情,所以我什至不知道从哪里开始。任何帮助,将不胜感激。谢谢! 最佳答案 无论Rails是什么,几乎所有Web应用程序都有您的要求,大多数现代Web应用程序都需要相互通信。但是有一个小小的理解需要你坚持下去,网站不应直接访问彼此
我正在使用Sequel构建一个愿望list系统。我有一个wishlists和itemstable和一个items_wishlists连接表(该名称是续集选择的名称)。items_wishlists表还有一个用于facebookid的额外列(因此我可以存储opengraph操作),这是一个NOTNULL列。我还有Wishlist和Item具有续集many_to_many关联的模型已建立。Wishlist类也有:selectmany_to_many关联的选项设置为select:[:items.*,:items_wishlists__facebook_action_id].有没有一种方法可以
我使用的是Firefox版本36.0.1和Selenium-Webdrivergem版本2.45.0。我能够创建Firefox实例,但无法使用脚本继续进行进一步的操作无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055)错误。有人能帮帮我吗? 最佳答案 我遇到了同样的问题。降级到firefoxv33后一切正常。您可以找到旧版本here 关于ruby-无法在60秒内获得稳定的Firefox连接(127.0.0.1:7055),我们在StackOverflow上找到一个类
在Cooper的书BeginningRuby中,第166页有一个我无法重现的示例。classSongincludeComparableattr_accessor:lengthdef(other)@lengthother.lengthenddefinitialize(song_name,length)@song_name=song_name@length=lengthendenda=Song.new('Rockaroundtheclock',143)b=Song.new('BohemianRhapsody',544)c=Song.new('MinuteWaltz',60)a.betwee
我正在检查一个Rails项目。在ERubyHTML模板页面上,我看到了这样几行:我不明白为什么不这样写:在这种情况下,||=和ifnil?有什么区别? 最佳答案 在这种特殊情况下没有区别,但可能是出于习惯。每当我看到nil?被使用时,它几乎总是使用不当。在Ruby中,很少有东西在逻辑上是假的,只有文字false和nil是。这意味着像if(!x.nil?)这样的代码几乎总是更好地表示为if(x)除非期望x可能是文字false。我会将其切换为||=false,因为它具有相同的结果,但这在很大程度上取决于偏好。唯一的缺点是赋值会在每次运行
导读语言模型给我们的生产生活带来了极大便利,但同时不少人也利用他们从事作弊工作。如何规避这些难辨真伪的文字所产生的负面影响也成为一大难题。在3月9日智源Live第33期活动「DetectGPT:判断文本是否为机器生成的工具」中,主讲人Eric为我们讲解了DetectGPT工作背后的思路——一种基于概率曲率检测的用于检测模型生成文本的工具,它可以帮助我们更好地分辨文章的来源和可信度,对保护信息真实、防止欺诈等方面具有重要意义。本次报告主要围绕其功能,实现和效果等展开。(文末点击“阅读原文”,查看活动回放。)Ericmitchell斯坦福大学计算机系四年级博士生,由ChelseaFinn和Chri
之前说过10之后的版本没有3dScan了,所以还是9.8的版本或者之前更早的版本。 3d物体扫描需要先下载扫描的APK进行扫面。首先要在手机上装一个扫描程序,扫描现实中的三维物体,然后上传高通官网,在下载成UnityPackage类型让Unity能够使用这个扫描程序可以从高通官网上进行下载,是一个安卓程序。点到Tools往下滑,找到VuforiaObjectScanner下载后解压数据线连接手机,将apk文件拷入手机安装然后刚才解压文件中的Media文件夹打开,两个PDF图打印第一张A4-ObjectScanningTarget.pdf,主要是用来辅助扫描的。好了,接下来就是扫描三维物体。将瓶
Heroku支持人员告诉我,为了在我的Web应用程序中使用自定义字体(未安装在系统中,您可以在bash控制台中使用fc-list查看已安装的字体)我必须部署一个包含所有字体的.fonts文件夹里面的字体。问题是我不知道该怎么做。我的意思是,我不知道文件名是否必须遵循heroku的任何特殊模式,或者我必须在我的代码中做一些事情来考虑这种字体,或者如果我将它包含在文件夹中它是自动的......事实是,我尝试以不同的方式更改字体的文件名,但根本没有使用该字体。为了提供更多详细信息,我们使用字体的过程是将PDF转换为图像,更具体地说,使用rghostgem。并且最终图像根本不使用自定义字体。在
📢博客主页:https://blog.csdn.net/weixin_43197380📢欢迎点赞👍收藏⭐留言📝如有错误敬请指正!📢本文由Loewen丶原创,首发于CSDN,转载注明出处🙉📢现在的付出,都会是一种沉淀,只为让你成为更好的人✨文章预览:一.分辨率(Resolution)1、工业相机的分辨率是如何定义的?2、工业相机的分辨率是如何选择的?二.精度(Accuracy)1、像素精度(PixelAccuracy)2、定位精度和重复定位精度(RepeatPrecision)三.公差(Tolerance)四.课后作业(Post-ClassExercises)视觉行业的初学者,甚至是做了1~2年
在我让另一个人重做我的前端UI之前,我的Rails应用程序运行平稳。我已经尝试解决此错误3天了。这是错误:Nosuchfileordirectory-identifyExtractedsource(aroundline#59):575859606162@post=Post.find(params[:id])authorize@postif@post.update_attributes(post_params)flash[:notice]="Postwasupdated."redirect_to[@topic,@post]else{"utf8"=>"✓","_method"=>"patc