ну на сколько я знаком с перлов то у него енсть 3 типа доступа к данным из запроса:
fetchrow_array
fetchrow_arrayref
fetchrow_hashref
(что значат посмотрите в мануале лень описывать).
ну про это написано в мане но как то вскользь
fetchrow_array Возвращает следующую запись как массив
fetchrow_arrayref Возвращает следующую запись как ссылку на массив
fetchrow_hashref Возвращает следующую запись как ссылку на хеш
fetchall_arrayref Возвращает всю информацию как массив массивов
fetchrow_array
Этот метод выбирает очередную строку данных и возвращает ее как массив значений полей. Пример:
while(@row = $sth -> fetchrow_array) {
print qw($row[0]\t$row[1]\t$row[2]\n);
}
fetchrow_arrayref
Этот метод выбирает очередную строку данных и возвращает ссылку на массив значений полей. Пример:
while($row_ref = $sth -> fetchrow_arrayref) {
print qw($row_ref ->
- \t$row_ref -> [1]\t$row_ref ->
[2]\n);
}
fetchrow_hashref
Этот метод выбирает строку данных и возвращает ссылку на хеш, содержащий пары имя/значение. Данный метод намного менее эффективен, чем использование пописанных выше ссылок на массивы. Пример:
while($hash_ref = $sth -> fetchrow_hashref) {
print qw($hash_ref -> {firstname}\t$hash_ref ->
{lastname}\t$hash_ref ->{title}\n);
}
fetchall_arrayref
Этот метод выдает все данные (все строки), получаемые как результат SQL-запроса. Он возвращает ссылку на массив ссылок на массивы отдельных строк. Соответственно, для обращения к этим данным нужно использовать вложенный цикл. Пример:
my $table = $sth -> fetchall_arrayref
or die "$sth -> errstr\n";
my($i, $j);
for $i ( 0 .. $#{$table}} ) {
for $j ( 0 .. $#{$table -> [$i]} ) {
print "$table -> [$i][$j]\t";
}
print "\n";
}
все и больше нигде не нахожу инфы которая рассмотрела бы каждый случай более подробно чтобы разобраться
например:
qw($row_ref -> - \--кусочек который мне не ясен
что за qw? а дальше что есть что? где строка? где переменная? где столбец?
ну и в том же плане разобрать все остальное