Влияет ли физическое соединение оракула на производительность при его закрытии - PullRequest
0 голосов
/ 15 мая 2019

Я занимаюсь разработкой приложения для моего проекта на последний год, мне нужно быстрое разъяснение по java JDBC. Я использую физическое соединение с Oracle (нет пула соединений).Когда пользователь выполняет поиск по критериям поиска, выполнение запроса происходит за 10 мс, а возврат набора результатов в пользовательский интерфейс занимает до 1 минуты.Код прилагается.

Connection con=null;
        OracleConnection ocon = null;
        ResultSet rs = null;
        Gson gson = new Gson();
        String gsonOrdrHeaderEntity="";
        JSONObject searchObject = new JSONObject();
        JSONObject returnSearchObject = new JSONObject();
        CallableStatement callableStatement = null;  
        ArrayList<SearchEntity> searchArrayList = new ArrayList<>();

        try{
            con= DatasourceConfiguration.openConnection();
            ocon = (OracleConnection)con.unwrap(OracleConnection.class);

            callableStatement= con.prepareCall("call SEARCHPKG.QUERY(?,?,?,?,?)");  

            callableStatement.setString(1,entity.getSearch1());
            callableStatement.setString(2,entity.getSearch2());
            callableStatement.setString(3,entity.getSearch3());
            callableStatement.setString(4,entity.getSearch4());

            callableStatement.registerOutParameter(5, OracleTypes.CURSOR);

            callableStatement.execute();

             rs = ((OracleCallableStatement) callableStatement).getCursor(39);

            if(rs != null)
             while(rs.next()) {
                 OrderHeaderEntity searchEntity = new OrderHeaderEntity();
                                 searchEntity.setSearch1(rs.getString(1));
                                 searchEntity.setSearch2(rs.getString(3));
                                 searchEntity.setSearch3(rs.getString(4));
                                 searchEntity.setSearch4(rs.getString(5));

                                 /**
                                  * Description : Since there are will multiple order in a single search, we are adding the row to an array and iterating over it
                                  */
                                 searchArrayList.add(searchEntity);
             }


        }catch(SQLException e){
            logger.info("SQLException while performing search: "+e.getMessage());
            throw e;
        }catch(Exception e){
            logger.info("Exception while performing search: "+e.getMessage());
        }finally {
            try {
                if(rs != null) {rs.close();}
            } catch (Exception e2) {
                logger.info("Error while closing the search resultSet : "+e2.getMessage());
            }

            try {
                if(callableStatement!=null) {callableStatement.close();}
            } catch (Exception e2) {
                logger.info("Error while closing the search callableStatment :"+e2.getMessage());
            }
            finally {
        }
                try {
                    if(con!=null) {con.close();}
                } catch (Exception e2) {
                    logger.info("Error while the search connection :"+e2.getMessage());
                }


            }

        }
        /**
         * @Description : mapping result set with JAVA object
         */

        logger.info("Inside ProcedureCall >> search Proc>> converted to JSON successfully");

          gsonOrdrHeaderEntity= gson.toJson(searchArrayList); 

          searchObject.put("order_header", gsonOrdrHeaderEntity);

          returnSearchObject.put("status", "success");
          returnSearchObject.put("message","Order Header Retrieved Successfully");
          returnSearchObject.put("data", searchObject);




        return returnSearchObject.toString();
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...