Scala Slick过滤并加入

Aze*_*eli 4 scala slick

在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)
Run Code Online (Sandbox Code Playgroud)

val query = for {
 (cof, sup) <- coffees.filter(_.price < 9.0) join supplier on(_.supId === _.id)
} yield (cof.name, sup.name)
Run Code Online (Sandbox Code Playgroud)

ula*_*las 5

第一个是隐式连接,第二个是显式连接.Slick WHERE为前者生成一个条款,如:WHERE c.price < 9 AND c.supId = s.id.然而,后者产生了JOIN类似的JOIN supplier s ON c.supId = s.id.您可以查看这些示例.

  • 我认为[this](http://stackoverflow.com/questions/44917/explicit-vs-implicit-sql-joins)将是您问题的答案. (2认同)