gpt4 book ai didi

mysql - 查询中记录的行号

转载 作者:行者123 更新时间:2023-11-29 06:52:08 25 4
gpt4 key购买 nike

我需要在查询中找到记录的页码。我有偏移量和限制,但还需要行号来计算。

给定一个查询对象和一个记录 ID,我如何找到行号?

行号应该是相对于查询表的。 limit 和 offset 将在之后应用。

感谢任何帮助...

最佳答案

让记录的“页码”像这样倒退有点尴尬,通常一个系统想要从记录的“细节”跳回“所有记录的分页 View ”只会将页码带到“详细信息”页面。

但假设您使用的是功能强大的数据库,您可以使用 window function 从任意 SELECT 语句中获取行号,您可以通过 Postgresql、SQL Server 或 Oracle(尤其不是 MySQL 或 SQLite)等数据库获得。

使用 PG 我们可以从一些数据开始:

test=> create table data(id SERIAL primary key, value varchar(20));
NOTICE: CREATE TABLE will create implicit sequence "data_id_seq" for serial column "data.id"
NOTICE: CREATE TABLE / PRIMARY KEY will create implicit index "data_pkey" for table "data"
CREATE TABLE
test=> insert into data (value) values ('d1'), ('d2'), ('d3'), ('d4'), ('d5'), ('d6'), ('d7'), ('d8'), ('d9'), ('d10'), ('d11'), ('d12'), ('d13'), ('d14'), ('d15'), ('d16');
INSERT 0 16

然后我们可以选择此数据并使用 row_number() 窗口函数获取整数行计数:

test=> select value, row_number() over (order by id) as rownum from data;
value | rownum
-------+--------
d1 | 1
d2 | 2
d3 | 3
d4 | 4
d5 | 5
d6 | 6
d7 | 7
d8 | 8
d9 | 9
d10 | 10
d11 | 11
d12 | 12
d13 | 13
d14 | 14
d15 | 15
d16 | 16
(16 rows)

在子查询中应用窗口数据,我们可以根据这个计数选择结果的切片:

test=> select value from (select value, row_number() 
> over (order by id) as rownum from data) as sub where rownum between 5 and 10;
value
-------
d5
d6
d7
d8
d9
d10
(6 rows)

因此,如果您有记录“d14”并且页面大小为 5,您可以这样做:

test=> select (rownum - 1) / 5 from (select value, row_number() 
> over (order by id) as rownum from data) as sub where value='d14';
?column?
----------
2
(1 row)

SQLAlchemy 通过 over() 提供窗口函数方法/函数,因此假定为此使用典型 ORM 映射的 SQLA 查询如下所示:

subq = session.query(
Data.value,
func.row_number().over(order_by=Data.id).label('rownum')
).subquery()
pagenum = session.query((subq.c.rownum - 1) / 5).\
filter(subq.c.value == 'd14').scalar()

就使用窗口函数与分页限制/偏移量而言,值得查看 comparison我在这里写了比较各种方法的性能,以及 windowed range query我有时使用的食谱。

关于mysql - 查询中记录的行号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14697538/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com