【发布时间】:2009-10-17 13:48:37
【问题描述】:
我正在使用 php 和 sqlite 开发一个简单的投票系统。我预先构建了一个完整的场景并在 sqlite 命令行中对其进行了测试,它运行良好。 但是一个查询应该返回所有可能的投票答案以及投票给它的用户,它不再起作用了......
表格:
CREATE TABLE polls (
question CHAR(200)
);
CREATE TABLE choices (
poll_id INTEGER(5),
choice_text CHAR(200)
);
CREATE TABLE votes (
poll_id INTEGER(5),
user_id INTEGER(5),
choice_id INTEGER(5),
PRIMARY KEY (poll_id, user_id)
);
CREATE TABLE users (
name CHAR(100),
pass CHAR(100),
session CHAR(100)
);
PHP:
$query = "SELECT choices.rowid,choices.choice_text,
(SELECT users.name FROM users WHERE votes.user_id=users.rowid) AS name
FROM choices,polls LEFT OUTER JOIN votes ON choices.rowid = votes.choice_id
WHERE polls.rowid=choices.poll_id AND polls.rowid='$pollid'";
$result = $db->arrayQuery($query, SQLITE_ASSOC);
echo json_encode($result);
这会返回:
Warning: SQLiteDatabase::arrayQuery() [sqlitedatabase.arrayquery]: no such column: votes.user_id in C:\Users\jan\Eigene Programme\xampplite\htdocs\cattle\vote\update.php on line 122
false
我尝试的第一件事是将子查询更改为
(SELECT users.name FROM users,votes WHERE votes.user_id=users.rowid) AS name
这可行,但不会返回相同的结果:/ 由于我不是专业人士,我对该查询进行了很长时间的修改,所以我想可能会有更好的查询?
【问题讨论】: