Scala Slick过滤并加入
发布时间:2020-12-16 18:01:17 所属栏目:安全 来源:网络整理
导读:在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) joi
在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.
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |