加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

scala – 在Slick中获得单个结果的最有效方法是什么?

发布时间:2020-12-16 10:05:45 所属栏目:安全 来源:网络整理
导读:我想知道以下哪两行更有效: db.run(events (..filter/sort..) .take(1).result.head) 要么 db.run(events (..filter/sort..) .result.head) 正如我发现.take来自slick.lifted.Query 和.head来自slick.profile.BasicStreamingAction 解决方法 下面使用take(1
我想知道以下哪两行更有效:

db.run(events (..filter/sort..) .take(1).result.head)

要么

db.run(events (..filter/sort..) .result.head)

正如我发现.take来自slick.lifted.Query

和.head来自slick.profile.BasicStreamingAction

解决方法

下面使用take(1)的代码是有效的,因为take(1)转换为病态的SQL然后底层关系数据库的查询优化器进行优化以仅选择结果的第一行.

db.run(events (..filter/sort..) .take(1).result.head)

但是在应用程序层只有.head的情况下,slick不会将该代码转换为SQL,因此它不会传递给底层关系数据库.没有进行优化.当.head在应用程序级别完成时,将从关系数据库返回的符合条件的行中选择一行.在app层排第一行显然效率不高.

.take(1)将在SQL查询中转换为LIMIT 1.

.head在查询应用程序层的结果后给出结果集的第一个元素(结果集可能非常大,而且效率非常低且非常慢).

.take(1)只会在数据库级别提供一行.它非常非常有效.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读