perlでDBデータをセレクトし表示させるプログラムで
以下のように一回目のforループでは正常に表示されます。
二度目に表示させようとすると何もデータがなくなっているようです。
print でも、もちろんなにも表示しません。
配列名を変えてもだめでした。とこが原因なのかわかりません。
ステートメントハンドルとかが関係あるのでしょうか?
いろいろ調べたのですが、ちょっとわかりませんでした。
申し訳ないのですが、教えてください。
話をまとめるとDBからセレクトした同じ行のデータを2回表示させたいということです。
よろしくお願いします。
my $db = DBI->connect("DBI:Pg:dbname=$UDBNAME",$USERNAME,$USERPASS);
my $sth=$db->prepare(" select * from server where no = $no ");
$sth->execute;
#一回目
for ((my $count)=0; $count<$num_rows;$count++){
my @ar=$sth->fetchrow_array;
#二回目
for ((my $count)=0; $count<$num_rows;$count++){
my @ar=$sth->fetchrow_array;
No.3ベストアンサー
- 回答日時:
例えば、2要素をキーとする連想配列に貯めるとすると..
(未検証ですが)
my $db = DBI->connect("DBI:Pg:dbname=$UDBNAME",$USERNAME,$USERPASS);
my $sth=$db->prepare(" select * from server where no = $no ");
$sth->execute;
while(@ar=$sth->fetchrow_array)
{
if($count>=$num_rows){last;}
for(0 .. $#ar){$X{$count,$_}=$ar[$_];}
$count++;
}
print "例えば、3件目の第2フィールドは、",$X{2,1},"\n";
No.2
- 回答日時:
$sth->fetchrow_arrayを2回呼び出すと言うことは、データベースから
”2回読み出す”ことになりますが、それでよろしいですか?
普通は、データベースから読み出す行為は、処理時間がかかるので行いません。
もし、その辺の課題を理解した上で、2回読み出したいのであれば、
$sth->execute;
を、もう一度処理してください。その後、fetchrow_arrayが動作できます。
一般的には、効率を優先し、自分の配列に一度蓄えた後、複数回利用するのが
多いと思います。
ご回答ありがとうございます。
もしよろしければ
一般的には、効率を優先し、自分の配列に一度蓄えた後、複数回利用するのが
多いと思います。 のサンプルを教えていただけませんか?
よろしくお願いします。
No.1
- 回答日時:
DBから直接処理した配列は一回使用すると消えてしまうみたいですねー。
もう一回Selectするか、
一回目のforの時に別の配列に入れるしかないのかもしれないです。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- CGI perlで書いたcgiでsqliteの使い方を教えてください 2 2023/05/08 21:29
- PHP PHP ページング データベース 1 2022/06/16 10:30
- PHP php my adminより取り出したデータ表示 2 2022/06/15 11:56
- PHP PHP MySql ページング 2 2022/09/20 06:38
- Visual Basic(VBA) ファイル全てを .xlsm に変更したところ、プログラムが途中で落ちてしまっています 17 2022/12/07 12:03
- C言語・C++・C# このプログラミングの問題を教えて欲しいです。 キーボードから整数kを入力し、kが配列aの中に何個存在 2 2022/12/19 22:50
- PHP PHPでCookieを使った訪問回数について 1 2023/05/28 14:10
- C言語・C++・C# このプログラミングの問題を教えてほしいです。 キーボードからデータ数nとn個のデータを入力し、平均値 3 2022/12/19 22:51
- PHP htmlで複数の個数入力欄を表示させるには 1 2022/09/20 03:11
- Visual Basic(VBA) 前回ご教授いただいたコードに覚えたてのループ処理で品名りんごAから順に20回for nextでループ 7 2023/01/13 22:01
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
QNo.3258883データベースから取...
-
組み合わせを作るアルゴリズム
-
プログラミングについて。 1つ...
-
画面を強制的に再描画させる方法
-
DoEventsが必要な理由について
-
エクセルの当番表を作っていま...
-
VBAで3秒だけ時間を止めたい
-
ループ内での条件処理
-
DOSコマンドのループ内のTIMEコ...
-
アクティブセルから、A列最終行...
-
文字列を変数名として扱う方法
-
VBA Dir関数でファイルをループ...
-
VBA for i=1 to lastrow
-
UWSCの終了の仕方
-
GIFアニメをループさせたくない
-
チェックデジットについて
-
for文とforeach文について
-
while(*s++=*t++)の判定は?
-
範囲指定したセルを1つずつ飛...
-
英語でのシャープとコメの呼び...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
データベースから取得したデー...
-
perlで2つの配列を比較する方...
-
DBIを使ってのデータの取り出し...
-
python質問
-
perlでファイルの拡張子を除い...
-
アルファベットn文字の組み合わ...
-
grep関数を用いた複数行からの抽出
-
乱数と順列と組み合わせ
-
半角文字の縦書き表示
-
配列やハッシュで中身が同じか...
-
ループ中でのmy宣言と処理速度
-
桁数指定と四捨五入
-
画面を強制的に再描画させる方法
-
VBAで3秒だけ時間を止めたい
-
VBAでの一時停止と再開の方法
-
VBのReturnの使い方
-
どなたかこのプログラミングを...
-
Escキーを押すと、中断する時と...
-
UWSCの終了の仕方
-
エクセルの当番表を作っていま...
おすすめ情報