0

datareader による odbcconnection からの応答から値を取得するたびに、データベースへの接続を作成しました (9 つのフィールドを返すクエリがある場合、db への接続は 9 つです)。すべての情報を取得します。それは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);
4

2 に答える 2

1

いいえ、別のクエリ方法が必要です。

フィールドごとに 1 つのクエリを実行する代わりに、SELECT一度に 9 つすべてを実行して、すぐに接続を閉じます。

このアプローチのもう 1 つの問題は、階層化がまったくないことです。UI とデータベース コードを一緒に混ぜたくありません。あなたの方法で抽象化はありません。

于 2012-02-10T10:16:03.513 に答える
0

選択クエリの StringBuilder と AppendLine を使用してみてください。あなたのdbReaderをループして、私が思いつくことができる最高のリストに保存してください。9 つの異なるクエリで 1 つの呼び出しが必要であることは理解していますが、いずれにせよ、SQL マシンまたはプログラム マシンにオーバーヘッドが発生します。

于 2012-02-10T12:46:50.727 に答える