我正在尝试弄清楚如何使用流畅的流媒体。我使用 slick 3.0.0 和 postgres 驱动程序
情况如下:服务器必须将客户端数据序列拆分为受大小(以字节为单位)限制的块。所以,我写了以下精巧的查询:
val sequences = TableQuery[Sequences]
def find(userId: Long, timestamp: Long) = sequences.filter(s ⇒ s.userId === userId && s.timestamp > timestamp).sortBy(_.timestamp.asc).result
val seq = db.stream(find(0L, 0L))
我将 seq 与 akka-streams 结合起来Source
,编写了 custom PushPullStage
,它限制了数据的大小(以字节为单位)并在达到大小限制时完成上游。它工作得很好。问题是 - 当我查看 postgres 日志时,我看到这样的查询
select * from sequences where user_id = 0 and timestamp > 0 order by timestamp;
因此,乍一看,似乎有很多(并且不必要的)数据库查询正在进行,只是在每个查询中使用了几个字节。使用 Slick 进行流式传输以最小化数据库查询并充分利用每个查询中传输的数据的正确方法是什么?