在我的 PHP 单元测试中,我使用的是 SQLite 内存数据库,其中包含下表:
CREATE TABLE "battlegroup_request" (
"id" INTEGER NULL PRIMARY KEY AUTOINCREMENT,
"battlegroupID" INTEGER NULL,
"inviterID" INTEGER NULL,
"inviteeID" INTEGER NULL
)
当我使用两个整数绑定执行以下查询时;
SELECT *
FROM "battlegroup_request"
WHERE "inviteeid" = ? AND
"inviter" IS NOT NULL AND
"battlegroupid" = ?
LIMIT 1
该查询返回一个结果,但我希望它会引发错误,因为该列inviter
不存在。这是 SQLite 的预期行为吗?难道我做错了什么?
我正在使用 PDO,连接创建如下:
new PDO(
'sqlite::memory:',
null,
null,
array(
PDO::ATTR_CASE => PDO::CASE_LOWER,
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
PDO::ATTR_ORACLE_NULLS => PDO::NULL_NATURAL,
PDO::ATTR_STRINGIFY_FETCHES => false,
PDO::ATTR_EMULATE_PREPARES => false,
)
);
(这些选项是Laravel的默认选项,也就是我们正在使用的框架。)