Scala Slick过滤和连接

6
在Slick中执行过滤连接时,以下两种方法在底层有什么区别?
val query = for {
 c <- coffees if c.price < 9.0
 s <- c.supplier -- assuming there is a foreign key
} yield (c.name, s.name)

并且

val query = for {
 (cof, sup) <- coffees.filter(_.price < 9.0) join supplier on(_.supId === _.id)
} yield (cof.name, sup.name)
1个回答

8
第一个是隐式连接,第二个是显式连接。Slick 生成前者的 WHERE 子句如下:WHERE c.price < 9 AND c.supId = s.id。然而,后者会生成像这样的 JOINJOIN supplier s ON c.supId = s.id。你可以看一下这些示例

好的,这就是我的答案。也许我应该问一下为什么你想要做其中之一而不是另一个。 - Azeli
2
我认为这个链接可能是你问题的答案。 - ulas

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接