perl: 資料庫編程

來源:互聯網
上載者:User

標籤:dbi   dbd   

DBI:串連所有資料庫的API。


DBD:是DBI針對不同資料庫的驅動。
DBD::mysql
DBD::Pg
DBD::SQLite


如果沒有,使用cpan安裝即可。
######################################################################
DBI介面:


習慣用法:
$dbh資料庫控制代碼
$sth語句控制代碼
$drh驅動控制代碼
$rc布爾類型返回碼
$rv整數類型返回值
@ary從資料庫返回的行記錄的列表
$rows處理的行數
$fh檔案控制代碼
\%attr雜湊類型的屬性


@driver_names= DBI->available_drivers;

%dirvers= DBI->installed_drivers;
@data_sources= DBI->data_sources($driver_name, \%attr);
$dbh= DBI->connect($data_source, $username, $auth, \%attr);


###########################################################
use   DBI;


#用connect建立串連返回控制代碼
$dsn= “DBI:mysql:database=$database;host=$hostname;port=$port”;
$dbh= DBI->connect($dsn, $username, $password, {RaiseError => 1,AutoCommit => 0});

#for   select
$sth= $dbh->prepare(“SELECT foo,bar FROM user WHERE baz=?”);
$sth->execute($baz );
while( @row = $sth->fetchrow_array) {
    print“@row\n”;
    “@row\n”;
}


#for  non-select(create,drop,alter,insert,delete)
$sth= $dbh->prepare(“INSERT INTO table(foo,bar,baz) VALUES(?,?,?)”);
while(<CSV>) {
    chomp;
    my($foo, $bar, $baz) = split /,/;
    ($foo, $bar, $baz) = split /,/;
    $sth->execute($foo,$bar, $baz);
    $bar, $baz);
}


$rows_affected= $dbh->do(“UPDATE your_table SET foo = foo + 1”);


$dbh->commit;
$dbh->rollback;
$sth->finish;
$dbh->disconnect;


具體API參考文檔。

perl: 資料庫編程

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.