0

我通过首先创建一个临时表并用 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

4 回答 4

1

您的临时查询正在寻找比您的 ID 更大的 ID,因此下一个查询不会找到小于该 ID 的任何内容。

于 2013-07-07T07:42:03.007 回答
1

你需要DESC从你的get_previous函数中删除。用我的替换这一行:

$orm = $db->query("SELECT * FROM pr WHERE ID < $id ORDER BY ID LIMIT 1;");
于 2013-07-07T07:45:05.310 回答
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;

我希望这有帮助...

于 2013-07-07T08:15:11.650 回答
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
于 2013-07-07T08:00:28.963 回答