繁体   English   中英

如何在mysql数据库中插入相关行?

[英]How do I insert a related row into a mysql database?

我完全迷住了。 我在数据库中设置了两个表,一个称为主题,一个称为页面。 我在数据库中为页面指定了subject_id,以将其连接至主题。 我已经动态显示了一个包含主题和子页面的导航。 我还创建了一些php文件,用于删除主题,编辑主题和编辑页面。 现在,我在每个主题上都添加了一个链接,以便在单击主题时将您带到一个页面,希望可以在所选的父主题下添加一个新页面。 还值得注意的是,我在链接中发送了父主题ID以添加页面。 这是我认为以某种方式给我带来问题的部分代码:

if(empty($errors)){
$id = mysql_prep($_GET['subj']);
$menu_name = mysql_prep($_POST['menu_name']);
$position = mysql_prep($_POST['position']);
$visible = mysql_prep($_POST['visible']);
$content = mysql_prep($_POST['content']);

$subject = get_subject_by_id($id));//This fetches the subject id from the db

$query = "INSERT INTO
pages WHERE subject_id = $subject
(
menu_name, position, visible, content
) VALUES (
'{$menu_name}', {$position}, {$visible}, '{$content}'
)";
$result = mysql_query($query, $db_connect);      
if (mysql_affected_rows() == 1){

echo "<p>suceess</p>";
} else { ....

我知道这是脱离上下文的,但是我认为有人发现问题可能会有些运气。 如果有人对此有任何见解,我将不胜感激。

插入语句中不能包含where子句。

没有where子句,表将获得插入的行。 如果您尝试更新现有的行(这将证明where子句是合理的),则需要使用update语句。

正确的INSERT语法是:

INSERT INTO pages (subject_id, menu_name, position, visible, content) VALUES (?,?,?,?,?)

当然,请绑定适当的参数,并且不要使用字符串插值

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM