PerlでDBへNULLを書き込む時のvaluef関数

Perl初心者のためのPerlノートです!

HTML/ CSS/ CGI-Perl/ JavaScript/ JavaApplet/ AccessUp/ Internet/ EnglishLearn/ ちゃいちゃん天使/ 天使メッセージ/ 飯田ワールド/ 結城ワールド/ プロフィール/ WEB相談室/ WEBアンテナ/ WEBリーダー/ 燈明日記/ yahoo

◆ はじめに

本ページは、私がPerlを習得した時(いや習得中)のノートです。

ごく普通の言語(COBOL,C,Java,VB等)を知っている人が、Perlをやり始めるといろいろと悩むことがあります。

それは、

です。

本ページは、そのようなハードルを一つ一つクリアにしていけたらと思います。

そして、本ページが何かのお役に立てれば幸いです。では、ごゆっくりご覧ください。

尚、ご感想、ご意見、誤字、脱字、間違い等がありましたら遠慮なくPerlノート掲示板へご指摘ください。

◆ サイト最新情報

◆ コンテンツ

■ PerlでDBへNULLを書き込む時のvaluef関数

SQLのINSERTやUPDATEで書き込むデータを指定する時に、通常、文字列はシングルクォーテーションで囲み、数値とNULLはそのままになります。

しかし、数値に関してはシングルクォーテーションで囲んでも問題がないですね。


上記を踏まえて、Perlでvaluefという関数を作ってみました。

valuef関数は、引数が空文字列と未定義値の時はNULLとし、これ以外(数値と文字列)の時は、値をシングルクォーテーションで囲みます。

#!/usr/bin/perl
use strict;
my @Sql = ();
my $Code=15;
my $Level=();
my $Comment='11111111111';
$Sql[0] = "INSERT INTO tstTBL (Code, Level, Comment) ";
$Sql[0] .= "VALUES (@{[valuef($Code)]}, @{[valuef($Level)]}, @{[valuef($Comment)]}) ";
&SQLExecutor(@Sql);

sub valuef {
   my ($para) = @_;
   my $rtvalue;
   if (($para eq '') || (!defined($para))) {
       $rtvalue = 'NULL';
   }
   else {
       $rtvalue = "'" . $para . "'";
   }
   return $rtvalue;
}

sub SQLExecutor {
use Win32::OLE;
Win32::OLE->Option(Warn => 3); 

    my (@Sql) = @_;
    # データベースへの接続
    my $objDB = Win32::OLE->new("ADODB.Connection");
    # SQL Server 認証設定(WINDOWS認証の時は『Integrated Security=SSPI;』を付加する)
    my $connectStr = "Provider=sqloledb;".
                     "Data Source=SERVER_NAME;".
                     "Initial Catalog=DB_NAME;".
                     "User ID=sa;".
                     "Password=sa;";
    # 接続を開く
    $objDB->Open($connectStr);
    if ($objDB->{Errors}->{Count}) {
        die "cannot connect '$connectStr'";
    }
    $objDB->{CommandTimeout} = 100;
    foreach  my $wkSQL (@Sql) {
        # データ更新
        $objDB->Execute($wkSQL);
    }
    # 接続を閉じる
    $objDB->Close();
}

尚、SQLExecutorサブルーチンは、SQL Server系のDB専用です。

留意点として、SERVER_NAMEとDB_NAMEとsaは、本番用に書き換えが必要です。

◆ おすすめ Perl本

■ 続・初めてのPerl 改訂版

『初めてのPerl』の次ぎに読むと吉です。

結構いいですが・・・、初心者にはちょっと難しいかもです。

■ 結城浩のPerlクイズ

この本には、ちゃいちゃんパパの小話しが載っています(謎)。

ある程度、Perlを理解している人には、たまらない内容になっています。さすが結城先生だな!

結城浩のPerlクイズ

■ 新版Perl言語プログラミングレッスン入門編

実は、私はまだ読んでいませんが、結城先生の本なので良くないはずがありません。

新版Perl言語プログラミングレッスン入門編

■ CGI&Perlポケットリファレンス (Pocket reference)

この本は、非常に役に立ちます。ちょっと調べるのに最適です。サンプルも説明も的を射ています。

CGI&Perlポケットリファレンス (Pocket reference)

■ Perlベストプラクティス

一読の価値有りだと思います。

Perlベストプラクティス

■ プログラミングPerl〈VOLUME1〉

ご存知、Perl本の聖書、ラクダ本(上)です。

■ プログラミングPerl〈VOLUME2〉

ご存知、Perl本の聖書、ラクダ本(下)です。

◆ おわりに

最後に、本ページが、何かのお役に立てれば幸いです。

尚、ご感想、ご意見、誤字、脱字、間違い等がありましたら遠慮なくPerlノート掲示板へご指摘ください。

HTML/ CSS/ CGI-Perl/ JavaScript/ JavaApplet/ AccessUp/ Internet/ EnglishLearn/ ちゃいちゃん天使/ 天使メッセージ/ 飯田ワールド/ 結城ワールド/ プロフィール/ WEB相談室/ WEBアンテナ/ WEBリーダー/ 燈明日記/ yahoo

人のよいところをどんどん見つけよう