光滑3 - upsert工作太慢

时间:2015-09-23 09:15:55

标签: scala slick

我使用upsert列表items

的流动代码
case class Item(id: String, text: String)

class Items(tag: Tag) extends Table[Item](tag, "items"){
    ...
}

val tbl = TableQuery[Items]

def insertItems(items: List[Item]):Future[Int] = {
    val q = DBIO.sequence(items.map(tbl.insertOrUpdate).toSeq).map(_.sum)
    db.run(q)
}

对于长度为2000的items列表,upsert需要大约10秒。太长了......

我认为,大部分时间都需要编译查询。

我应该如何重写insertItems来加速呢?

1 个答案:

答案 0 :(得分:3)

使用unique_ptr<char[]>this article)。 AFAIK,插入的编译查询在光滑2.0之后可用。

此外,要插入列表,您应该执行批处理操作,而不是逐个插入记录。

因此,在Slick-3.0中,对于插入,你应该这样做:

compiled queries

然后运行另一个查询以获取所需列的总和。

编辑:我不认为,光滑支持批量insertOrUpdate语句。如果底层数据库支持批量insertOrUpdate,则最快的方法是编写纯SQL。否则编译的val tblCompiled = Compiled(TableQuery[Items]) tblCompiled ++= items 查询应该快得多。

代码应该是

insertOrUpdate