[英]Insert multiple rows in one SQL statement in Groovy
我需要在一個語句中插入多個值。 使用groovy的預處理語句是否有可能? 我有以下
sql.execute("""
insert into all_priceuploaddummy (seller_sku) values (?.sku), (?.sku), (?.sku)
"""
, [[sku:1],[sku:2],[sku:3]])
但這會插入第一個SKU的3倍,即1
如何在不遍歷所有條目的情況下做到這一點?
您可以使用withBatch(String, Closure)
方法在批處理中執行關閉(包含特定於關聯的預處理語句的批處理操作)。
def updateCounts = sql.withBatch('insert into TABLENAME(a, b, c) values (?, ?, ?)') { ps ->
ps.addBatch([1, 2, 3])
ps.addBatch([10, 20, 30])
ps.addBatch(100, 200, 300)
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.