【发布时间】:2014-05-08 08:51:57
【问题描述】:
让我们考虑一下这张表:
+----------+----------+
| user_id | store_id |
+----------+----------+
| 39 | 8 |
| 8 | 39 |
| 5 | 11 |
+----------+----------+
我用 slick 映射它(删除索引和外键以简化它):
case class FavoriteStore(userId: Long, storeId: Long)
class FavoriteStoreTable(tag: Tag)
extends Table[FavoriteStore](tag, "FAVORITE_STORE") {
def userId = column[Long]("USER_ID")
def storeId = column[Long]("STORE_ID")
override def * = (userId, storeId) <>
(FavoriteStore.tupled, FavoriteStore.unapply)
}
我希望能够使用 Slick 编写以下 SQL 查询:
INSERT INTO favorite_store (user_id, store_id) VALUES (39, 8)
WHERE NOT EXISTS
(SELECT * FROM favorite_store WHERE user_id = 39 AND store_id = 8)
有什么想法吗?
【问题讨论】:
-
Slick 目前不支持 WHERE NOT EXISTS。请打开功能请求:github.com/slick/slick/issues/new
-
谢谢@cvogt,会的。