在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.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。