【踩坑笔记】解决Java *** 作MySQL8版本中与Batch相关的 *** 作

【踩坑笔记】解决Java *** 作MySQL8版本中与Batch相关的 *** 作,第1张

【踩坑笔记】解决Java *** 作MySQL8版本中与Batch相关的 *** 作

亲测有效!!!!搞了1个小时终于弄好了,如果有不对的地方请指出,防止带偏大家

我们在使用java *** 作数据库,,如果使用的MySQL版本为8(此处以8.0.27为例),可能会出现的问题

1.驱动,使用java连接MySQL8.0.27需要下载下面的驱动

下载mysql-connector-java-8.0.11.jarhttps://dev.mysql.com/downloads/file/?id=477058

2.java连接数据库(连接的数据库名为test,若数据库名称不同自行在url中进项修改)

我们使用Java *** 作向MySQL中添加大量的数据,如果需要使用与Batch有关的 *** 作(addBatch(),executeBatch(),clearBatch()),则需要进行如下的 *** 作

① 连接数据库时与MySQL5版本有所不同(不适用properties文件直接连接)

public void test4() throws Exception {
        String url = "jdbc:mysql://localhost:3306/test?serverTimezone=GMT%2B8&useUnicode=true&characterEncoding=utf8&autoReconnect=true&useSSL=false";
        String user = "root";
        String password = "abc123";//密码为自己MySQL设置

        Class.forName("com.mysql.cj.jdbc.Driver");//此处注意

        Connection conn = DriverManager.getConnection(url, user, password);
        System.out.println(conn);
    }

② 使用properties文件,需要对文件中的参数进项修改,我们如果想使用与Batch有关的 *** 作,MySQL默认情况下是禁止的,我们需要进项修改(注意密码为自己设置的)

​diverClass=com.mysql.cj.jdbc.Driver
url=jdbc:mysql://localhost:3306/test?serverTimezone=GMT%2B8&useUnicode=true&characterEncoding=utf8&autoReconnect=true&useSSL=false&rewriteBatchedStatements=true
user=root
password=abc123


​

此时,我们再执行Batch相关的 *** 作就可以正常执行

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zaji/5686062.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-17
下一篇 2022-12-17

发表评论

登录后才能评论

评论列表(0条)

保存