- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当我以这种方式获取数据时,是否可以访问列名和列类型,或者我是否需要明确的prepare
才能实现这一点?
use DBI;
my $dbh = DBI->connect( ... );
my $select = "...";
my @arguments = ( ... );
my $ref = $dbh->selectall_arrayref( $select, {}, @arguments, );
更新:
使用 prepare
我会这样做:
my $sth = $dbh->prepare( $select );
$sth->execute( @arguments );
my $col_names = $sth->{NAME};
my $col_types = $sth->{TYPE};
my $ref = $sth->fetchall_arrayref;
unshift @$ref, $col_names;
最佳答案
最好的解决方案是使用 prepare
获取语句句柄,如您在问题的第二部分中所述。如果你使用 selectall_hashref
或 selectall_arrayref
,你得不到语句句柄,必须自己通过 $dbh->column_info
查询列类型信息( docs ):
my $sth = $dbh->column_info('','',$table,$column); # or $column='' for all
my $info = $sth->fetchall_arrayref({});
use Data::Dumper; print Dumper($info);
(特别是 COLUMN_NAME 和 TYPE_NAME 属性)。
但是,如果表在两个查询之间更改架构,则会引入竞争条件。
关于perl - DBI:selectall_arrayref 和列名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12871496/
这两种模式在速度上有区别吗? selectall_arrayref( "SELECT * FROM $table", { Slice => { a => 1, b => 1 } } ); select
当我以这种方式获取数据时,是否可以访问列名和列类型,或者我是否需要明确的prepare才能实现这一点? use DBI; my $dbh = DBI->connect( ... ); my $sele
当我以这种方式获取数据时,是否可以访问列名和列类型,或者我是否需要明确的prepare才能实现这一点? use DBI; my $dbh = DBI->connect( ... ); my $sele
我是 perl 的新手(但来自 c# 背景),我正在尝试将一些脚本移动到 Windows 框。由于某些模块不能轻松地与 Windows 一起工作,我改变了它连接到数据库的方式。我有一个 sqlserv
我是一名优秀的程序员,十分优秀!