星星博客's Archiver

cnangel 发表于 2005-8-25 18:29

PERL与MySQL:DBI接口

[color=red]作者:小歪歪
email: [email]annysun@163.net[/email]
日期:2000-7-14 14:38:11[/color]
[b]通用DBI方法[/b]
[color=red]connect[/color]
  建立与一个数据库服务器的连接

[color=red]prepare[/color]
获取准备执行的SQL语句

[color=red]do[/color]
准备并执行一个SQL语句

[color=red]disconnect[/color]
断开与一个数据库服务器的连接

[color=red]quote[/color]
被插入引用字符串(块)

[color=red]execute[/color]
执行存储过程

[color=red]fetchrow_array[/color]
取出下一行到一个数组之中

[color=red]fetchrow_arrayref[/color]
取出下一行到数组中,返回数组的引用

[color=red]fetchrow_hashref[/color]
取出下一行到哈希表,返回其引用

[color=red]fetchall_arrayref[/color]
取出所有的数据到一个数组,返回其引用。

[color=red]finish[/color]
结束语句、释放系统资源

[color=red]rows[/color]
返回作用的行的数目

[color=red]data_sources[/color]
返回本机中可用的数据库的数组。

[color=red]ChopBlanks[/color]
去除空格

[color=red]NUM_OF_PARAMS[/color]
存储过程中占位符的数目

[color=red]NULLABLE[/color]
哪一个行允许Null。

[b]MySQL 的特殊方法[/b]
[color=red]insertid[/color]
最后自动递增的值

[color=red]is_blob[/color]
为BLOB的行

[color=red]is_key[/color]
为键的行

[color=red]is_num[/color]
为数字的行

[color=red]is_pri_key[/color]
为主键的行

[color=red]is_not_null[/color]
不能为NULL的行

[color=red]length[/color]
理论上最大的列的数目

[color=red]max_length[/color]
物理上最大的列的数目

[color=red]NAME[/color]
列名

[color=red]NUM_OF_FIELDS[/color]
返回的字段的数目

[color=red]table[/color]
返回的集中的表的名称

[color=red]type[/color]
行的类型

[color=red]_CreateDB[/color]
创建一个数据库

[color=red]_DropDB[/color]
删除一个数据库
[color=red]connect[/color]:使用connect方法建立一个到数据源的连接。$data_source应该以DBI:driver_name:开始,例如:
[code]
$dbh = DBI->connect("DBI:mysql:$database", $user, $password);
$dbh = DBI->connect("DBI:mysql:$database:$hostname",$user, $password);
$dbh = DBI->connect("DBI:mysql:$database:$hostname:$port",$user, $password);[/code]
如果用户名或者是口令没有定义的话,那么DBI将使用DBI_USER,DBI_PASS环境变量分别作为其值。如果你没有定义主机的话,那么默认的是“localhost”,如果你没有定义端口号的话,以默认的mysql的端口号(3306)作为端口号。
[color=red]prepare[/color]: 通过数据库引擎预备SQL语句并且返回一个语句句柄($sth)用于参与execute方法,例如:
[code]
$sth = $dbh->prepare($statement) or die "Can';t prepare $statement:
$dbh->errstr\n";[/code]
[color=red]do[/color] do方法预备并执行一个SQL语句,返回作用的行的数目,这个方法通常用于非select的语句,同时一般不需要执行多次(例如:insert,delete等)。例如:
[code]
$rc = $dbh->do($statement) or
        die "Can';t execute $statement: $dbh- >errstr\n";[/code]
[color=red]disconnect[/color] disconnect将断开与数据库的连接,通常在程序结束的时候使用。例如:
[code]
$rc = $dbh->disconnect;[/code]
[color=red]quote[/color] quote方法用于 "escape"任何在字符串中的特定自负,并且加上引用标记。
[code]
$sql = $dbh->quote($string)[/code]
[color=red]execute[/color] 该方法执行一个存储的语句。对于非select的语句来说,它返回作用的行的数目,对于select语句来说,该方法仅仅是开始了在数据库中查询,你需要fetch_*方法来取回数据。
[code]
$rv = $sth->execute or die "can';t execute the query: $sth->errstr;[/code]
[color=red]fetchrow_array[/color] 这个方法取回下一行的数据,并且将其存储在一个数组之中。例如:
[code]
while(@row = $sth->fetchrow_array) {
        print qw($row[0]\t$row[1]\t$row[2]\n);
}[/code]
[color=red]fetchrow_arrayref[/color] 这个方法取回下一行的数据,并将其返回在一个对数组的引用之中。例如:
[code]
while($row_ref = $sth->fetchrow_arrayref) {
        print qw($row_ref->[0]\t$row_ref->[1]\t$row_ref->[2]\n);
}[/code]
[color=red]fetchrow_hashref[/color] 这个方法取回一行数据,并且返回一个到包含了字段名/值的哈希表的引用。这个方法不如使用一个数组引用的方法有效率。例如:
[code]
while($hash_ref = $sth->fetchrow_hashref) {
        print qw($hash_ref->{firstname}\t$hash_ref->{lastname}\t\
                $hash_ref- > title}\n);
}[/code]
[color=red]fetchall_arrayref[/color] 这个方法被用来从一个SQL语句的执行结果中取回所有的数据(行)。它返回一个数组的引用,你可以通过一个循环来打印/显示这些数据。
[code]
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";
}[/code]
[color=red]finish[/color] 指示没有更多的数据可以被取出,你可以通过这个方法释放语句句柄,并且释放系统资源。例如:
[code]$rc = $sth->finish;[/code]
[color=red]rows[/color] 返回在(updated,delete等)操作中作用的行的数目。这通常被用在do()或者非select的execute()语句之后。例如:
[code]
$rv = $sth->rows;[/code]
[color=red]NULLABLE[/color] 返回一个数组的引用,TRUE分别表示这个列可以允许NULL。
[code]
$null_possible = $sth->{NULLABLE};[/code]
[color=red]NUM_OF_FIELDS[/color] 通过SELECT或者LISTFILEDS语句返回的列的数目。如果数目为0表示一个非SELECT语句的执行,例如,INSERT,DELETE或者UPDATE等。
[code]
$nr_of_fields = $sth->{NUM_OF_FIELDS};[/code]
[color=red]data_sources[/color] 这个方法返回在localhost中的mysql服务中可用的数据库的数组。
[code]
@dbs = DBI->data_sources("mysql");[/code]
[color=red]ChopBlanks[/color] 这个方法决定了返回的行中是否去除空格。
[code]
$sth->{';ChopBlanks';) =1;
[/code]
[b]<MySQL 特定方法>[/b]
[color=red]insertid[/color] 如果你使用了mysql的自动增值的特性,那么最新的自动增值将被存储。例如:
[code]
&#36;new_id = &#36;sth->{insertid};[/code]
[color=red]is_blob[/color] 返回一个数组的引用,TRUE分别表示所指示的列是BLOB。
[code]
&#36;keys = &#36;sth->{is_blob};[/code]
[color=red]is_key[/color] 返回一个数组的引用,TRUE分别表示所指示的列是KEY。
[code]
&#36;keys = &#36;sth->{is_key};[/code]
[color=red]is_num[/color] 返回一个数组的引用,TRUE分别表示所指示的列包含了数字。
[code]
&#36;nums = &#36;sth->{is_num};[/code]
[color=red]is_pri_key[/color] 返回一个数组的引用,TRUE分别表示所指示的列是一个主键。
[code]
&#36;pri_keys = &#36;sth->{is_pri_key};[/code]
[color=red]is_not_null[/color] 返回一个数组的引用,FALSE表示这个列可以包含NULL,而你最好使用DBI标准中的NULLABLE属性。
[code]
&#36;not_nulls = &#36;sth->{is_not_null};[/code]
[color=red]max_length[/color]、[color=red]length[/color] 返回一个指示最大列的尺寸的数组的引用。最大长度是指在结果的表中的最大数值,LENGTH给出了理论上的最大值。
[code]
&#36;max_lengts = &#36;sth->{max_length};
&#36;lengts = &#36;sth->{length};[/code]
[color=red]NAME[/color] 返回一个列名称的数组的引用。
[code]&#36;names = &#36;sth->{NAME};[/code]
[color=red]table[/color] 返回了表名称的数组的引用。
[code]&#36;tables = &#36;sth->{table};[/code]


页: [1]

Powered by Discuz! Archiver 7.0.0  © 2001-2009 Comsenz Inc.