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