Слишком много подключений к БД с использованием DataReader - PullRequest
0 голосов
/ 10 февраля 2012

Каждый раз, когда я получаю значение из ответа от odbcconnection от datareader, я устанавливал соединение с базой данных (если у меня есть запрос, который возвращает 9 полей, у меня есть 9 соединений с БД), и я хочу сделать только1 соединение и получить всю информацию.это возможно с datareader?Мне нужно использовать другой способ подключения?

С наилучшими пожеланиями.

Код:

    string strSql = "SELECT G.COMPANY_ID, U.USER_ID, U.GROUP_ID, U.NAME, U.DISPLAY_NAME, U.EMAIL, U.IS_CORPORATE, U.CALL_PARK, U.CALL_PICKUP, U.PCHUNTING, U.OUT_OF_OFFICE, U.DND, U.HOTLINE, U.PIN, U.FORCE_PIN_CHECKED, U.PCHUNTING_TYPE, U.DND_END_TIMESTAMP, U.DND_CONTACT, U.OUT_OF_OFFICE_TYPE, U.LANGUAGE, U.AVAILABLE_TIMESTAMP, U.LAST_DIALLED_NUMBER, U.LAST_INCOMING_CALL, U.LAST_MISSED_CALL, U.CALL_PICKUP_GROUP_ID, U.HOTLINE_NUMBER, U.PORTAL_PASSWORD, U.PROFILE, U.MAIN_NUMBER, U.DUAL_OUTGOING_CTRANSFER, U.MY_CALL_PICKUP, U.VM_RECONNECT_NOTIFY, U.SPARE_STRING1, U.INSERT_DATE, U.INSERT_USER, U.UPDATE_DATE, U.UPDATE_USER " +
                            "FROM {0}_TT_USER U LEFT OUTER JOIN {0}_TT_GROUP G ON  U.GROUP_ID = G.GROUP_ID " +
                            "WHERE USER_ID = :USER_ID ";

            conn = new OdbcConnection(GetIpCntrxTimestenConnString(opCode));
            cmd = new OdbcCommand(
                 string.Format(strSql
                             , config.GetIpCntrxEsmViewName(opCode))
                 , conn);

            cmd.Parameters.AddWithValue(":USER_ID", user_id);

            cmd.CommandType = CommandType.Text;
            conn.Open();

            dataReader = cmd.ExecuteReader();

            object[] meta = new object[dataReader.FieldCount];

            int NumberOfColums = dataReader.GetValues(meta);

Ответы [ 2 ]

1 голос
/ 10 февраля 2012

Нет, вам нужен другой способ запроса.

Вместо одного запроса на поле, SELECT все 9 сразу и сразу же закрывают соединение.

Еще одна проблема с этим подходом состоит в том, что нет наслоения вообще.Я не хотел бы смешивать пользовательский интерфейс и код базы данных вместе.Тебе нет никакой абстракции.

0 голосов
/ 10 февраля 2012

Попробуйте использовать StringBuilder и AppendLine ваши запросы выбора.Проходите через ваш dbReader и храните в списке, который является лучшим, что я могу придумать.Я понимаю, что вы хотите один вызов с 9 различными запросами, но в любом случае на вашем компьютере sql или на компьютере программы будут накладные расходы.

...