频 道 直 达 - 新闻 - 读书 - 培训 - 教程 - 前沿 - 组网 - 系统应用 - 安全 - 编程 - 存储 - 操作系统 - 数据库 - 服务器 - 专题 - 产品 - 案例库 - 技术圈 - 博客 - BBS
51CTO.COM_中国领先的IT技术网站
找资料:

PERL与MySQL(DBI接口)

作者: 51CTO.com整理 出处:51CTO.com  (  ) 砖  (  ) 好  评论 ( ) 条  进入论坛
更新时间:2005-09-09 10:46
关 键 词:接口  SQL  MySQL
阅读提示:本文是关于PERL与MySQL(DBI接口)的介绍性文章

通用DBI方法
<TABLE border=1 cellSpacing=1 width=624>
<TBODY>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>connect </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>建立与一个数据库服务器的连接</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>prepare </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>获取准备执行的SQL语句</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>do </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>准备并执行一个SQL语句</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>disconnect </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>断开与一个数据库服务器的连接</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>quote </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>被插入引用字符串(块)</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>execute </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>执行存储过程</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>fetchrow_array </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>取出下一行到一个数组之中</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>fetchrow_arrayref </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>取出下一行到数组中,返回数组的引用</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>fetchrow_hashref </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>取出下一行到哈希表,返回其引用</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>fetchall_arrayref </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>取出所有的数据到一个数组,返回其引用。</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>finish </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>结束语句、释放系统资源</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>rows </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>返回作用的行的数目</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>data_sources </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>返回本机中可用的数据库的数组。</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>ChopBlanks </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>去除空格 </SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>NUM_OF_PARAMS </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>存储过程中占位符的数目</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>NULLABLE </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN
class=text1>哪一个行允许Null。</SPAN></P></TD></TR></TBODY></TABLE><STRONG>
<P align=justify><SPAN class=text1>MySQL 的特殊方法</SPAN></P></STRONG>
<TABLE border=1 cellSpacing=1 width=624>
<TBODY>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>insertid </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>最后自动递增的值</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>is_blob </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>为BLOB的行</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>is_key </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>为键的行</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>is_num </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>为数字的行</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>is_pri_key </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>为主键的行</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>is_not_null </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>不能为NULL的行</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>length </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>理论上最大的列的数目</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>max_length </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>物理上最大的列的数目</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>NAME </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>列名</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>NUM_OF_FIELDS </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>返回的字段的数目</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>table </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>返回的集中的表的名称</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>type </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>行的类型</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>_CreateDB </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>创建一个数据库</SPAN></P></TD></TR>
<TR>
<TD vAlign=center>
<P align=justify><SPAN class=text1>_DropDB </SPAN></P></TD>
<TD vAlign=center>
<P align=justify><SPAN class=text1>删除一个数据库</SPAN></P></TD></TR></TBODY></TABLE>
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
哪一个行允许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);
}
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";
}
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;

<MySQL 特定方法>

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};


发表
查看
我也说两句

匿名发表

(如果看不清请点击图片进行更换)


中 国 领 先 的 IT 技 术 网 站 ·
技 术 成 就 梦 想
·Java基础教程 (查看51744次)
·UML类图详解 (查看46336次)
·Java编程开发手册 (查看24866次)
·UML统一建模语言 (查看23863次)
·C#技术开发指南 (查看21930次)
·Java编程开发手册 (1195个砖)
·Java基础教程 (429个砖)
·C#技术开发指南 (304个砖)
·PB开发教程 (220个砖)
·.NET开发手册 (217个砖)
·Java编程开发手册 (653个好)
·Java基础教程 (569个好)
·.NET开发手册 (248个好)
·PB开发教程 (208个好)
·Delphi开发技术手册 (174个好)
订阅技术快讯
电子杂志下载
名称:网络安全精品应用黄皮书
简介:《2007精品网络安全黄皮书》包括了9个大类24个小类, 800余篇文章,内容包含了熊猫烧香病毒、DDOS攻击、ARP病等热点问题的介绍及解决方案。从病毒查杀、防范、系统、数据等各方面的安全设置到黑客技术的了解、防范,涉及到了安全应用的全部领域, 由浅至深内容全面。
名称:Vista精品应用黄皮书
简介:《Vista精品应用黄皮书》囊括了Vista的各方面内容。此次的精简版,是将里面的内容做了提取,便于用户下载和使用。内容包含了各种Vista的安装与实施、技巧与解析以及各种Vista相关学习文档和相关软件的安全下载。该电子书是了解和应用Vista人员必备的工具手册,并且也是第一本
名称:2006中国IT论坛精品集合
简介:本书由“51CTO论坛推广联盟”制作完成。书中所有内容均来自各联盟成员的论坛(网站)。制作本书的目的是为了集中大家的优势资源,将更多更精彩的内容带给广大技术爱好者。本书是联盟成立以来制作的第一本书。
关键字阅读
频道精选
主编信箱 热线:010-66476606 告诉我们您想看的:专题 文章
关于我们 | 诚聘英才 | 联系我们 | 网站大事 | 意见反馈 | 网站地图
Copyright©2005-2007 51CTO.COM 版权所有