原因: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
就此,問題解決。