码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2019-07-10 10:49:41      阅读:206      评论:0      收藏:0      [点我收藏+]

标签:depend   date   ESS   更新   url路径   pen   wal   oda   one   

原因: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连接池不支持批量更新

标签:depend   date   ESS   更新   url路径   pen   wal   oda   one   

原文地址:https://www.cnblogs.com/xiaowangxiao/p/11161949.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!