Источник данных отклонил установление соединения, сообщение от сервера: «Слишком много соединений» java - PullRequest
0 голосов
/ 17 июня 2020

У меня есть 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;




    }
...