获取mysql中的下一个和上一个记录

时间:2013-07-07 07:36:18

标签: php mysql

我通过首先创建一个临时表并用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记录错误,因为它说前一条记录是当前记录。

我上次查询错误吗?。

4 个答案:

答案 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;

我希望这会有所帮助......

相关问题