SqlServer的批量upsert

本文介绍了如何在SQL Server中进行批量UPSERT操作,包括从临时表复制数据的方法,以及在Java中利用addBatch()函数实现批量更新或插入。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

从临时表复制

MERGE INTO (SELECT id,name,url from newweb) AS table
USING (SELECT ? sd id,? as name,? as url) AS data
ON table.id = data.id
WHEN MATCHED THEN
    UPDATE SET table.name = data.name,table.url=data.url
WHEN NOT MATCHED THEN
    INSERT(id,name,url) VALUES(data.id,data.name,data.url);

或者在java中使用addbatch()

import java.sql.*;
import java.util.Random;

public class upsert {
    public static void main(String[] args) {
        String url = "jdbc:sqlserver://172.16.1.66:1433;DatabaseName=StreamTest;";
        String user = "biwriter";
        String password = "biwriter";
        Connection conn=null;
        int id;
        String name;
        String weburl;
        Random r=new Random();
        CharacterUtils cu=new CharacterUtils();
        int n;
        int sum=0;

        try {
            //1.加载
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值