perl DBI/DBDの使い方
スポンサーリンク
DBIは、Perlから様々なデータベースにアクセスするための
データベースインターフェース(Database Interface)です。
DBIの特徴は、特定のデータベースに依存しない汎用性です。
MySQLやOracle等のDBMSの種類やバージョンに依存せずにプログラミング
することが可能になります。
DBD
DBIはインタフェースで、データベースに直接アクセスはしません。
DBDは各データベース用の専用のモジュールです。
DBIはDBDを通して、データベースにアクセスします。
データ作成
この例では、MySQLを利用します。
サンプルプログラム用にデータをmysqlに入れておきます。
DBへの接続
parepared statementを実行する
FreeBSDにp5-DBIとp5-DBD-mysqlをインストールする方法は、 [2008-05-14-1]
を参照してください。
データベースインターフェース(Database Interface)です。
DBIの特徴は、特定のデータベースに依存しない汎用性です。
MySQLやOracle等のDBMSの種類やバージョンに依存せずにプログラミング
することが可能になります。
DBD
DBIはインタフェースで、データベースに直接アクセスはしません。
DBDは各データベース用の専用のモジュールです。
DBIはDBDを通して、データベースにアクセスします。
データ作成
この例では、MySQLを利用します。
サンプルプログラム用にデータをmysqlに入れておきます。
% mysql -u root -p test mysql> create table users(id INTEGER NOT NULL PRIMARY KEY AUTO_INCREMENT, name varchar(32)); mysql> insert into users(name) values("a"); mysql> insert into users(name) values("b"); mysql> insert into users(name) values("c");
DBへの接続
$dbh = DBI->connect($dsn, $user, $password, {'RaiseError' =>1} )
DBの切断
$dbh->disconnect();
DBのエラーメッセージ
エラーがあった場合は、errstrにエラーメッセージが格納されます。
$dbh->errstr
parepared statementを準備する
プリペアドステートメントを作ります。
$sth = $dbh->prepare ( qq { SQL文 } ) or die $dbh->errstr;;
例
$sth = $dbh->prepare ( qq { SELECT * FROM users WHERE name = ? } ) or die $dbh->errstr;;
parepared statementを実行する
$rv = $sth->execute() or die $dbh->errstr;;
値を1つバインドするとき
$rv = $sth->execute($value1) or die $dbh->errstr;;
値を3つバインドするとき
$rv = $sth->execute($value1,$value2,$value3) or die $dbh->errstr;;
サンプルプログラム
#!/usr/local/bin/perl -w use strict; use warnings; use DBI; my $dbi = 'mysql'; my $database = 'test'; my $hostname = 'localhost'; my $dsn = "dbi:$dbi:database=$database;host=$hostname"; my $user = 'root'; my $password = ''; my $rv; my $dbh; $dbh = DBI->connect($dsn, $user, $password, {'RaiseError' => 1} ) or die $dbi->errstr; my $sth = $dbh->prepare( qq { SELECT * FROM users } ) or die $dbh->errstr; $rv = $sth->execute() or die $dbh->errstr; print "$rv\n"; # 取得できた数 while (my @row = $sth->fetchrow_array ) { print "@row\n"; } $dbh->disconnect(); exit;
FreeBSDにp5-DBIとp5-DBD-mysqlをインストールする方法は、 [2008-05-14-1]
を参照してください。
参照しているページ (サイト内): [2009-05-16-2] [2009-05-16-1] [2008-08-01-2] [2008-08-01-1] [2008-07-27-2] [2008-07-27-1] [2008-05-14-1]
スポンサーリンク
スポンサーリンク
いつもシェア、ありがとうございます!
もっと情報を探しませんか?
関連記事
最近の記事
- パナソニック ジェットウォッシャードルツ EW-DJ61-Wのホースの修理
- LinuxセキュリティモジュールIntegrity Policy Enforcement
- アマゾンのEcho Show 5を買ったのでレビューします
- アマゾンのサイバーマンデーはAlexa Echo Show 5が安い
- Android スマートフォン OnePlus 7T と OnePlus 7の違い
- Android スマートフォン OnePlus 7 をAndroid10にアップデートしてみた
- クレジットカードのバーチャルカードの比較のまとめ
- 活動量計 Xiaomi Mi Band 4を買ってみたのでレビュー
- Android スマートフォン OnePlus 7 のレビュー
- AliExpressでスマートフォンを買い物してみた
- パソコンのホコリ対策 レンジフードフィルターと養生テープ
- 80PLUS GOLDのPC電源ユニットAntec NeoEco 750 Goldのレビュー
- イギリスの付加価値税 VAT は払い戻しを受けられる
- イギリスのロンドンでスーツケースなど荷物を預けられる場所は
- イギリスのロンドンで地下鉄やバスに乗るならオイスターカードを使おう
- イギリスのヒースロー空港からロンドン市内への行き方
- 航空便でほかの航空会社に乗り継ぎがある場合のオンラインチェックイン
- SFC会員がANA便ではなくベトナム航空のコードシェアを試して解ったこと
- ベトナムの入国審査でeチケットの掲示が必要だった話
- シアトルの交通ICカードはオルカカード(Orca)です
人気のページ
- Windows7 IME 辞書ツールで単語の登録に失敗しました
- C言語 popen()でコマンドを実行して出力を読み込む
- Windows7で休止状態にする方法
- CentOS MySQLの起動、停止、再起動
- loggerコマンドでsyslogにエラーを出力する方法
- パソコンパーツの買取をしてくれる店のまとめ
- Java Mapの使い方 get(),put(),remove(),size(),clear()
- 楽天のRポイントカードを作ってみた
- iPhone 5 から iPhone 6 に乗り換えたのでレビュー
- netstatコマンドのステータスの意味
スポンサーリンク
過去ログ
2020 : 01 02 03 04 05 06 07 08 09 10 11 122019 : 01 02 03 04 05 06 07 08 09 10 11 12
2018 : 01 02 03 04 05 06 07 08 09 10 11 12
2017 : 01 02 03 04 05 06 07 08 09 10 11 12
2016 : 01 02 03 04 05 06 07 08 09 10 11 12
2015 : 01 02 03 04 05 06 07 08 09 10 11 12
2014 : 01 02 03 04 05 06 07 08 09 10 11 12
2013 : 01 02 03 04 05 06 07 08 09 10 11 12
2012 : 01 02 03 04 05 06 07 08 09 10 11 12
2011 : 01 02 03 04 05 06 07 08 09 10 11 12
2010 : 01 02 03 04 05 06 07 08 09 10 11 12
2009 : 01 02 03 04 05 06 07 08 09 10 11 12
2008 : 01 02 03 04 05 06 07 08 09 10 11 12
2007 : 01 02 03 04 05 06 07 08 09 10 11 12
2006 : 01 02 03 04 05 06 07 08 09 10 11 12
2005 : 01 02 03 04 05 06 07 08 09 10 11 12
2004 : 01 02 03 04 05 06 07 08 09 10 11 12
2003 : 01 02 03 04 05 06 07 08 09 10 11 12