• <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>
    • 軟件測試技術
    • 軟件測試博客
    • 軟件測試視頻
    • 開源軟件測試技術
    • 軟件測試論壇
    • 軟件測試沙龍
    • 軟件測試資料下載
    • 軟件測試雜志
    • 軟件測試人才招聘
      暫時沒有公告

    字號: | 推薦給好友 上一篇 | 下一篇

    PERL與MySQL(DBI接口)

    發布: 2007-7-04 20:04 | 作者: admin | 來源:  網友評論 | 查看: 9次 | 進入軟件測試論壇討論

    領測軟件測試網 通用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};

    文章來源于領測軟件測試網 http://www.kjueaiud.com/


    關于領測軟件測試網 | 領測軟件測試網合作伙伴 | 廣告服務 | 投稿指南 | 聯系我們 | 網站地圖 | 友情鏈接
    版權所有(C) 2003-2010 TestAge(領測軟件測試網)|領測國際科技(北京)有限公司|軟件測試工程師培訓網 All Rights Reserved
    北京市海淀區中關村南大街9號北京理工科技大廈1402室 京ICP備10010545號-5
    技術支持和業務聯系:info@testage.com.cn 電話:010-51297073

    軟件測試 | 領測國際ISTQBISTQB官網TMMiTMMi認證國際軟件測試工程師認證領測軟件測試網

    老湿亚洲永久精品ww47香蕉图片_日韩欧美中文字幕北美法律_国产AV永久无码天堂影院_久久婷婷综合色丁香五月

  • <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>