我通过首先创建一个临时表并用select语句中的数据填充来查询mysql数据库表。
为了测试它,我使用一个已知的数据库ID并测试它是否正确获取了下一个和前一个记录。
这是我的功能
function get_next($id){
$db = new PDO('mysql:host=localhost;dbname=world', 'root', '');
$db->query("CREATE TEMPORARY TABLE nr AS SELECT ID,Name,Population FROM city WHERE id > $id ORDER BY ID LIMIT 1;");
$orm = $db->query("SELECT * FROM nr WHERE ID > $id ORDER BY ID LIMIT 1;");
$id = $orm->fetchColumn(0);
if ($id !== false) {
return $id;
}
}
function get_previous($id){
$db = new PDO('mysql:host=localhost;dbname=world', 'root', '');
$db->query("CREATE TEMPORARY TABLE pr AS SELECT ID,Name,Population FROM city WHERE ID > $id ORDER BY ID LIMIT 1;");
$orm = $db->query("SELECT * FROM pr WHERE ID < $id ORDER BY ID DESC LIMIT 1;");
$id = $orm->fetchColumn(0);
if ($id !== false) {
return $id;
}
}
我可以正确获取next
记录,但我发现previous
记录错误,因为它说前一条记录是当前记录。
我上次查询错误吗?。
答案 0 :(得分:1)
您的临时查询正在查找大于您的ID的ID,因此下一个查询将找不到比该ID更小的内容。
答案 1 :(得分:1)
您需要从DESC
函数中删除get_previous
。请将此行替换为我的:
$orm = $db->query("SELECT * FROM pr WHERE ID < $id ORDER BY ID LIMIT 1;");
答案 2 :(得分:0)
我不会使用临时表,因为你只对id感兴趣,所以你不需要检索其他信息
# To retrieve the previous id:
SELECT MAX(id) FROM city WHERE id < $id
# alternative:
SELECT id FROM city WHERE id < $id ORDER BY id DESC LIMIT 1
# To retrieve the next id:
SELECT MIN(id) FROM city WHERE id > $id
# alternative:
SELECT id FROM city WHERE id > $id ORDER BY id ASC LIMIT 1
答案 3 :(得分:0)
上一行
SELECT * FROM table WHERE id < 1 ORDER BY id DESC LIMIT 1;
下一行
SELECT * FROM table WHERE id > 1 ORDER BY id ASC LIMIT 1;
我希望这会有所帮助......