zoukankan      html  css  js  c++  java
  • 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

    就此,问题解决。

  • 相关阅读:
    当前毫秒时间戳
    生成随机指定长度的字符串
    symfony框架学习
    Git 学习一
    jmeter逻辑控制器
    jmeter执行顺序及作用域规则
    jmeter常用测试元件
    windows环境下jmeter生成测试报告
    jmeter参数化
    对网页进行截图(selenium)
  • 原文地址:https://www.cnblogs.com/xiaowangxiao/p/11161949.html
Copyright © 2011-2022 走看看