
お世話になっております。
ArrayListを2つ使用して2次元配列のような事をしようとしております。
データベースから取得したデータの1行をArrayListItemへ格納してそのArrayListItemをArrayListRecordへ格納しようとしております。
追加し終わり最後にArrayListRecordの中身を見ると全て一番最後のデータで置き換わっています。
どなたかご存知でしたらお教え願います。
' 変数宣言
Dim objSqlDR As SqlDataReader
Dim alSetItem As ArrayList
Dim alSetRecord As ArrayList
alSetItem = New ArrayList
alSetRecord = New ArrayList
' データ取得分ループ
While objSqlDR.Read()
alSetItem.Clear()
For intSetIndex = 0 To (objSqlDR.FieldCount - 1)
alSetItem.Add(objSqlDR(intSetIndex))
Next intSetIndex
alSetRecord.Add(alSetItem)
End While

No.2ベストアンサー
- 回答日時:
alSetRecord.Add(alSetItem)
これは alSetItem の現在の値を alSetRecord に追加しているのではなく、alSetItem へのポインタを alSetRecord に追加しています。
よって alSetRecord に alSetItem のポインタがいくつ追加されようとも、全ては「ただ 1つの」alSetItem オブジェクトを指してしまうわけです。
そして alSetItem の中身はというと、最後のループで登録された中身なわけです。
alSetRecord.Add(alSetItem)
これを
alSetRecord.Add(alSetItem.Clone())
とするとか。
No.1
- 回答日時:
全てのレコードを個別に保持したいならば、ArrayList は1レコードずつ new しなければいけません。
この例では、while 直後の clear() によって、データが全て消えてしまっています。
end while 直前の .add() によって行われているのは、「クラス alSetItem をレコードとして登録する」という動作であり、値そのものをポイッと放り込んでいるわけではありません。
よって、この例を正しく修正するには、"alSetItem = New ArrayList" の行を、while の直後に移動します。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
【C#】DataGridViewの最大列数...
-
wordの差し込み印刷で文字...
-
VB6でDBからクリップボード経由...
-
VisualBasic2010のPictureBoxに...
-
ActiveReportのサブレポート機...
-
GridViewからチェックボックス...
-
スクレイピングに関して
-
WordでExcelデータを差込...
-
excel access連携 このテーブル...
-
MSFlexGridのデータを初期化し...
-
C言語で地図を描きたい
-
★お手上げ状態です。助けてくだ...
-
Dosブロンプトでtabを出力したい
-
【VBA】EXCELブックを開かずに...
-
shシェルスクリプト 空白行の...
-
PHP 九九表
-
ファイル名に日付の挿入
-
CSVファイルをブラウザのキャッ...
-
switch()文で値の大小比較
-
VBAでPDFファイルの文書のプロ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
【C#】DataGridViewの最大列数...
-
wordの差し込み印刷で文字...
-
DTOとEntityの差は何ですか。
-
excel access連携 このテーブル...
-
WordでExcelデータを差込...
-
C#でのForm間のデータ受け渡し...
-
★お手上げ状態です。助けてくだ...
-
IDに欠番があった場合のupdate処理
-
携帯の対応について質問!!
-
VBA内でのGetPixelを使用した時...
-
htmlやCGIでのデータの送信につ...
-
JavaからPHPへの値の受け渡し
-
Amazon APIについて
-
ASPでの検索画面の作り方について
-
INIファイルに一括書き込みを行...
-
「外部データの取り込み」とい...
-
VB6.0とスプレッドシート
-
blog トラックバック機能
-
TCPでデータを受け取ってそれを...
-
Windowsのマクロプログラムで、...
おすすめ情報