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)

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

解决方法

第一个是隐式连接,第二个是显式连接. Slick为前者生成一个WHERE子句,如:WHERE c.price< 9 AND c.supId = s.id.然而,后者生成一个JOIN,如JOIN供应商的ON c.supId = s.id.你可以看看 these examples.

相关文章

共收录Twitter的14款开源软件,第1页Twitter的Emoji表情 Tw...
Java和Scala中关于==的区别Java:==比较两个变量本身的值,即...
本篇内容主要讲解“Scala怎么使用”,感兴趣的朋友不妨来看看...
这篇文章主要介绍“Scala是一种什么语言”,在日常操作中,相...
这篇文章主要介绍“Scala Trait怎么使用”,在日常操作中,相...
这篇文章主要介绍“Scala类型检查与模式匹配怎么使用”,在日...