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

就此,問題解決。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM