У меня есть api, выполняющий несколько запросов в mysql, я запускал этот метод несколько раз, отображается сообщение об ошибке слишком много подключений, я пытаюсь закрывать каждый раз подключение после выполнения запроса, но это не решает мою проблему
@PostMapping(value="/checkSql")
public ArrayList ExecuteSql(@RequestBody SQLBody sqlBody) {
Connection con = null;
Statement stmt = null;
ResultSet rs = null;
ArrayList array = new ArrayList();
DataSource datatsource = dataSource( sqlBody.getUsername(),sqlBody.getPassword(),sqlBody.getUrl(),sqlBody.getDriver());
try {
List<Fonctionnalite> listFonctionalite = findAllMP();
for( Fonctionnalite item : listFonctionalite) {
con = datatsource.getConnection();
stmt = con.createStatement();
FileReader fr=new FileReader("C:\\Users\\jihed\\OneDrive\\Bureau\\versionfinalPfe2020\\f2\\"+item.getName()+"\\"+item.getFileChek());
int i;
StringBuffer sb = new StringBuffer();
while((i=fr.read())!=-1) {
sb.append((char)i);
}
System.out.println(sb);
fr.close();
rs = stmt.executeQuery(sb.toString());
ResponseChek check = new ResponseChek(item.getId(),item.getName(),item.getDesscription(),item.getFileActivation(),item.getFilaDesactivation(),item.getFileChek(),1);
array.add(check);
if(rs != null) rs.close();
if(stmt != null) stmt.close();
if(con != null) con.close();
}
} catch (SQLException | IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
try {
if(rs != null) rs.close();
if(stmt != null) stmt.close();
if(con != null) con.close();
if(datatsource != null) datatsource = null;
} catch (SQLException e) {
e.printStackTrace();
}
}
return array;
}