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で質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
画像が表示でnull; this.src
-
テキストファイルで提出とは?
-
INDIRECT 横に再度抽出したい
-
アルファベットに付いて質問し...
-
Raspberry Pi
-
Perl 特定のフォルダ以外削除
-
Perl言語について。
-
ファイルをディレクトリ分配の...
-
#!/usr/bin/perlで書きだしたCG...
-
Perlのエラーについてご教授く...
-
perlのflock関数でロックをかけ...
-
AI sisterとは、偽物の人ですか?
-
bashスクリプト
-
ファイルアイコンの左下に緑の□...
-
perlプログラミング 空白行削除
-
perlでリテラル値はメモリにど...
-
perlで2次元配列をサブルーチ...
-
Perlで時間の計算
-
perlについて
-
perlのrequireの動き方について...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
perlで2つの配列を比較する方...
-
perlでファイルの拡張子を除い...
-
python質問
-
ソート時同じ値がある場合、表...
-
データベースから取得したデー...
-
サブルーチンと繰り返し処理を...
-
DBIを使ってのデータの取り出し...
-
配列やハッシュで中身が同じか...
-
ファイルの最後の行から表示さ...
-
配列内定義サブルーチン呼び出し
-
grep関数を用いた複数行からの抽出
-
配列に格納した文字列の置換
-
二桁の数字からなる配列数10...
-
重複する領域を統合する方法
-
正規表現 perl 連続ヒットの...
-
ループ中でのmy宣言と処理速度
-
ハッシュ内の各値部分に配列を...
-
UWSCの終了の仕方
-
画面を強制的に再描画させる方法
-
VBのReturnの使い方
おすすめ情報