springboot集成druid连接池不支持批量更新

Posted xiaowangxiao

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了springboot集成druid连接池不支持批量更新相关的知识,希望对你有一定的参考价值。

原因:Druid的防火墙配置(WallConfig)中变量multiStatementAllow默认为false;

解决方案:设置Druid的防火墙配置(WallConfig)中变量multiStatementAllow=true,新建DruidDataSource配置类

配置类代码:

@Configuration
public class DataSourceConfig 

    @Autowired
    WallFilter wallFilter;

    @Bean    //声明其为Bean实例
    @Primary  //在同样的DataSource中,首先使用被标注的DataSource
    @ConfigurationProperties(prefix = "spring.datasource")
    public DataSource dataSource()
        DruidDataSource datasource = new DruidDataSource();

        // filter
        List<Filter> filters = new ArrayList<>();
        filters.add(wallFilter);
        datasource.setProxyFilters(filters);

        return datasource;
    

    @Bean(name = "wallFilter")
    @DependsOn("wallConfig")
    public WallFilter wallFilter(WallConfig wallConfig)
        WallFilter wallFilter = new WallFilter();
        wallFilter.setConfig(wallConfig);
        return wallFilter;
    

    @Bean(name = "wallConfig")
    public WallConfig wallConfig()
        WallConfig wallConfig = new WallConfig();
        wallConfig.setMultiStatementAllow(true);//允许一次执行多条语句
        wallConfig.setNoneBaseStatementAllow(true);//允许一次执行多条语句
        return wallConfig;
    

然后修改sql连接url路径:声明allowMultiQueries=true;参考路径方式:

url: jdbc:mysql://localhost:3306/ies? allowMultiQueries=true&autoReconnect=true&useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=CONVERT_TO_NULL&useSSL=false&serverTimezone=Hongkong

就此,问题解决。

以上是关于springboot集成druid连接池不支持批量更新的主要内容,如果未能解决你的问题,请参考以下文章

SpringBoot--集成Druid连接池

SpringBoot随笔-SpringBoot集成Druid

SpringBoot随笔-SpringBoot集成Druid

springboot 集成druid

SpringBoot2.0 基础案例(07):集成Druid连接池,配置监控界面

springboot集成Druid 作为数据库连接池