在PHP中的Prepared语句中设置SQL变量不起作用
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了在PHP中的Prepared语句中设置SQL变量不起作用,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2635字,纯文字阅读大概需要4分钟。
内容图文
![在PHP中的Prepared语句中设置SQL变量不起作用](/upload/InfoBanner/zyjiaocheng/907/2075f20700fc4867bb180989f67298e7.jpg)
情况:我有一个包含testFK,questionFK和ordinal列的联结表.
testFK | questionFK | ordinal
2 14 1
2 15 2
2 16 3
_____________________________
NEW 2 17 4
我想在testFK = 2和questionFK = 17的表中添加一个新行,但是,我希望根据表中已有的内容自动生成序号.由于最高序数是3,所以我希望SQL自动生成4.
我试过了:
$stmt = $db->prepare('
SET @QOrdinal = (SELECT MAX(ordinal) FROM junc_test_question WHERE testFK = ?);
INSERT
INTO junc_test_question
(junc_test_question.testFK, junc_test_question.questionFK, junc_test_question.ordinal)
VALUES (?, ?, @QOrdinal);
');
$stmt->bind_param('iii', $this->testID, $this->testID, $question_id);
//var_dump($stmt);
if($stmt->execute()) {
return true;
} else {
return false;
}
如果我对序数进行硬编码,这是有效的,但我似乎无法让SQL自己做.
任何输入都非常感谢!
更新:
我得到的错误
Fatal error: Call to a member function bind_param() on a non-object in \classes\Test.php on line 91
所以我假设SQL不正确.
解决方法:
在OP最近的评论的背景下,下面提出的解决方案并不恰当.
如果使用MyISAM表类型并定义自动增量列为第2个的主键,则MyISAM automatically calculates为第1个字段分组的增量(请参阅链接文档中的MyISAM注释):
For MyISAM tables, you can specify AUTO_INCREMENT on a secondary
column in a multiple-column index. In this case, the generated value
for the AUTO_INCREMENT column is calculated as
MAX(auto_increment_column) + 1 WHERE prefix=given-prefix. This is
useful when you want to put data into ordered groups.
所以,你可以简单地按如下方式定义表 – 虽然在实践中,我不确定我是否会存储这个序数:
DROP TABLE IF EXISTS my_table;
CREATE TABLE my_table
(testFK INT NOT NULL
,ordinal INT NOT NULL AUTO_INCREMENT
,questionFK INT NOT NULL
,PRIMARY KEY(testFK,ordinal)
) ENGINE = MYISAM;
INSERT INTO my_table VALUES
(2,1,14),
(2,2,15),
(2,3,16);
INSERT INTO my_table (testFK,questionFK) VALUES
(2,17);
SELECT * FROM my_table;
+--------+---------+------------+
| testFK | ordinal | questionFK |
+--------+---------+------------+
| 2 | 1 | 14 |
| 2 | 2 | 15 |
| 2 | 3 | 16 |
| 2 | 4 | 17 |
+--------+---------+------------+
或者,你可以按照这些方式做一些事情(简化) – 但我从不认真提倡这个解决方案:
INSERT INTO my_table (testFK,questionFK,ordinal)
SELECT 2,18,MAX(ordinal+1) FROM my_table;
SELECT * FROM my_table;
+--------+---------+------------+
| testFK | ordinal | questionFK |
+--------+---------+------------+
| 2 | 1 | 14 |
| 2 | 2 | 15 |
| 2 | 3 | 16 |
| 2 | 4 | 17 |
| 2 | 5 | 18 |
+--------+---------+------------+
内容总结
以上是互联网集市为您收集整理的在PHP中的Prepared语句中设置SQL变量不起作用全部内容,希望文章能够帮你解决在PHP中的Prepared语句中设置SQL变量不起作用所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。