PreparedStatement 批处理

 

// 同条Sql语句  可以使用绑定变量
public static void main(String[] args) {
        //声明Connection对象
        Connection con;
        //驱动程序名
        String driver = "com.mysql.cj.jdbc.Driver";
        //URL指向要访问的数据库名mydata
        String url = "jdbc:mysql://localhost:3306/test?characterEncoding=UTF-8&serverTimezone=GMT&useSSL=false";
        //MySQL配置时的用户名
        String user = "root";
        //MySQL配置时的密码
        String password = "123456";
        //遍历查询结果集
        try {
            //加载驱动程序
            Class.forName(driver);
            //1.getConnection()方法,连接MySQL数据库!!
            con = DriverManager.getConnection(url, user, password);
            if (!con.isClosed())
                System.out.println("Succeeded connecting to the Database!");
            //2.创建statement类对象,用来执行SQL语句!!

            String sql = "insert into account(username,name,age) values(?,?,?)";

//            PreparedStatement preparedStatement = con.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);
            PreparedStatement preparedStatement = con.prepareStatement(sql);

            for(int i=1;i<=10;i++) {
                preparedStatement.setString(1,String.valueOf(i));
                preparedStatement.setString(2,String.valueOf(i));
                preparedStatement.setString(3,String.valueOf(i));

                preparedStatement.addBatch();

            }

            int[] updateResults = preparedStatement.executeBatch();

            System.out.println("updateResults="+ Arrays.toString(updateResults));

            preparedStatement.clearBatch();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

// 多条sql  不能使用绑定变量
public static void main(String[] args) {
        //声明Connection对象
        Connection con;
        //驱动程序名
        String driver = "com.mysql.cj.jdbc.Driver";
        //URL指向要访问的数据库名mydata
        String url = "jdbc:mysql://localhost:3306/test?characterEncoding=UTF-8&serverTimezone=GMT&useSSL=false";
        //MySQL配置时的用户名
        String user = "root";
        //MySQL配置时的密码
        String password = "123456";
        //遍历查询结果集
        try {
            //加载驱动程序
            Class.forName(driver);
            //1.getConnection()方法,连接MySQL数据库!!
            con = DriverManager.getConnection(url, user, password);
            if (!con.isClosed())
                System.out.println("Succeeded connecting to the Database!");
            //2.创建statement类对象,用来执行SQL语句!!

            String sql = "insert into account(username,name,age) values(?,?,?)";

//            PreparedStatement preparedStatement = con.prepareStatement(sql, Statement.RETURN_GENERATED_KEYS);
            PreparedStatement preparedStatement = con.prepareStatement(sql);

            preparedStatement.addBatch("insert into account(username,name,age) values(\"11\",\"11\",\"11\")");
            preparedStatement.addBatch("insert into account(username,name,age) values(\"21\",\"21\",\"21\")");

            int[] updateResults = preparedStatement.executeBatch();

            System.out.println("updateResults="+ Arrays.toString(updateResults));

            preparedStatement.clearBatch();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值