ADOとMySQL関数の比較

WEBサイト作成

ADOとMySQL関数の比較


MVCモデルはインターフェイスであるViewerが要求を受け付けて、Controllerが内部処理して、Modelがデータベースに格納する、という3層構造になっているので、テーマ変更と追加処理とデータ構造変更の3つを、限りなくお互いの影響を排除しながら、分業化して行なうことができます。

開発プラットフォームとしてのCMS

WordPressなどのCMSは豊富なテンプレートやプラグインがあるので企業ホームページやポータルサイトなどのデザイン重視のWebサイト作成向きであり、僕のようにデザインセンスに自信のない人間にとっては大幅な開発工数短縮が可能になります。

またCMSなので投稿や固定ページの追加・修正・削除が容易であり、ブログ機能であるカテゴリ化、タグ付け、アーカイブなどによるデータ整理が楽であり、保守性に秀でています。

一方、頻繁にDB処理を行なうデータ処理中心のWEBサイト開発の場合は、CMS独自のテーブル構造やファイル構成の制約を受けるデメリットが強く働き、そもそもCMSの強みが発揮できないため、PHPでライブラリを使いながらスクラッチ開発したり、フレームワークを使ってMVCモデル(処理Model-出力Viewer-入力Controller)開発することになります。

多くのマスタデータを新設する必要がある業務系サイトではCMSの出る幕は少ないでしょう。

MVCモデルはインターフェイスであるViewerが要求を受け付けて、Controllerが内部処理して、Modelがデータベースに格納する、という3層構造になっているので、テーマ変更と追加処理とデータ構造変更の3つを、限りなくお互いの影響を排除しながら、分業化して行なうことができます。

CMSが開発プラットフォームとして利用されるとすれば、今後も参照系システム中心になると思われます。

MySQL関数

VBのADOでレコードセットから値を取り出す場合と異なる点は、mysql_queryで返された結果(2次元配列)にアクセスするためには、結果リソースをレコード(行)単位で mysql_fetch_array関数にてフィールド数分の配列として取得する必要があること。

Dim cn As ADODB.Connection
Dim rs As ADODB.Recordset
Set cn = New ADODB.Connection
Set rs = New ADODB.Recordset

Dim query, email As String

query="select * from patient where EMAIL='" & email & "'"
rs.Open query, cn, adOpenKeyset, adLockOptimistic

Do Until rs.EOF
    //VBの場合レコードセットからテーブルのフィールド名指定で値が取り出せる。
    MsgBox rs!SEI
    MsgBox rs!MEI

    rs.MoveNext
Loop

つまりADOの場合Query実行結果を2次元配列であるrs(レコードセット)に格納し、レコードセットからフィールド名を指定することで値を取得し、レコードセットに対して直接MoveNextで行を進めていくが、MySQLの場合mysql_query関数によるQuery実行結果を2次元配列であるret(レコードセット)に格納し、レコード単位にmysql_fetch_array関数でで配列に格納した上でフィールドの値を取得する。

フォームからデータを入力

if(isset($_POST["email"])){
    $email = $_POST["email"];
}

<form action="index.php" method="POST">
<input type="text" name="email" />
<input type="submit" />
</form>

DBに接続

mysql_connect($server,$user,$password);
mysql_select_db($dbname);
mysql_query('set names utf8');

SET NAMESが使えない場合はINSERT文で日本語をDBに挿入する場合、以下の文字化け防止処理をする。

mysql_set_charset("utf8");

入力データを元にQueryを実行

//SELECTの場合は検索結果を$retに格納(まだ2次元配列ではない)
$query="select * from patient where EMAIL='".$email."'";
$ret=mysql_query($query);

//INSERTの場合
$query2="insert into patient(SEI, MEI) ";
$query2.="values ('".$full_name1."','".$full_name2."'')";
mysql_query($query2);

レコードセットの行数と列数を取得(値の取得のためのループの最大値として使用)

$numRow=mysql_num_rows($ret); //レコード数(行数)
$numCol=mysql_num_fields($ret); //フィールド数(列数)

Queryの結果を表示

$rowをmysql_fetch_arrayの戻り値とした場合、$row[0]にSEIの値, $row[1]にMEIの値, $row[2]にEMAILの値が入り、もう一度 戻り値を$rowとしてmysql_fetch_arrayを実行すると、その次の行が同じ変数に格納される。

ちなみに似たようなMysql関数にmysql_fetch_assocというのがあるんですが、こちらは添え字配列専門です。

//レコード数の回数だけを繰り返す
for($i=0;$i<$numRow;$i++){
    echo '';
    //取得した行に対する配列を返し内部データポインタを前に進める。
    $row=mysql_fetch_array($ret);
    //フィールド(列)の数の回数だけ繰り返す
    for($j=0; $j<$numCol;$j++){
        $str=$row[$j];
        $str=htmlspecialchars($str);  //クロスサイトスクリプティング対策
        echo ''.$str.'';
    }
    echo '';
}

以下のようにwhileとforeachを使えばよりシンプルになります。mysql_fetch_arrayは繰り返し実行するだけで次のレコードに進む(rs.MoveNextみたいに)してくれるところがポイントです。

while($row=mysql_fetch_array($ret)){
    echo "";    //配列$rowのインデックス番号$keyと値$valueを取得
    foreach($row as $key => $value){
        $value=htmlspecialchars($value);  //クロスサイトスクリプティング対策
        echo ''.$value.'';
    }
echo "";
}

mysql_fetch_arrayがFalesを返すまで(取得すべき行が存在しない)ループし、その中でforeachにより配列のキーと値(列の値)を取り出す。foreachはwhile文やfor文などと異なり繰り返しが終了される条件式は存在せず、配列の要素の数だけ繰り返して終了する。

DBから切断

mysql_close();

ライブラリを使用する

PEARのライブラリPEAR MDB2でDB接続
Smartyでコードビハインド(ロジックがphpファイル、デザインがtplファイル)

ライブラリの読み込み

require_once 'MDB2.php';
require_once 'Smarty/Smarty.class.php';

フォームからのデータを取得

if(isset($_POST["email"])){
    $email = $_POST["email"];
}

DBに接続

$dsn='mysql://$user:$password@$server/$dbname?charset=utf8';
$con=MDB2::connect($dsn);

入力されたデータを元にQueryを実行

//SELECTの場合は検索結果を$retに格納(まだ連想配列ではない)
$sql=sprintf("select * from patient where EMAIL='".$email."'");
$ret=$con->query($sql);

//今回は先にレコードセットのrowを配列に格納してしまう
$data=array();
while ($row=$result->fetchRow(MDB2_FETCHMODE_ASSOC)){
    $data[]=$row;
}

SmartyのテンプレートにQuery結果を表示

$smarty=new Smarty();
$smarty->assign('data', $data);
$smarty->display('index.tpl')

テンプレートファイル

//コードビハインドなのでtplにあるのはタグとSmarty関数のみ
<form action="index.php" method="POST"><input type="text" name="email" />
<input type="submit" /></form>

{foreach from=$data item=row}

{/foreach}





おすすめ記事一覧

1

よく会計の世界では「利益と減価償却でキャッシュを作る」と言われ、これは企業のキャッシュの源泉が利益と減価償却の二種類あるという意味なのですが、減価償却費はキャッシュの流出のない費用であり、P/L上の当期利益額よりも実際には減価償却費分だけキャッシュは多く残っているという数字遊びをしているだけで、物理的にキャッシュが生み出されるわけではありません。

2

毎月の生産でいくらコストがかかったかを計算する原価計算(実際原価)業務は、インドネシアではシステム化されている事例は少なく、細かく計算すれば時間がかかり、どんぶり勘定だと見たい情報が見られず、コロナ禍の影響で時間に余裕が出来た今は収益改善という観点から原価計算のやり方を見直す絶好の機会です。

3

ジャカルタでは、2019年4月にMRT地下鉄の第1期区間(総延長15.7km)が正式開通しましたが、コロナ禍の中にあった今年6月に、現在の始発駅であるPlaza Indonesia前のBendaran HI駅から、北ジャカルタのKotaまでの6.3km、西ジャカルタのアンチョールの車両基地までの5.2kmの総延長11.5km(11駅)を第2期区間として工事が開始されました。

4

2014年に誕生したジョコウィ政権は、事あるごとに中国寄りと言われ、2015年に中国と日本が受注合戦を繰り広げ日本の新幹線方式での導入が確実視されていたジャカルタ~バンドゥン高速鉄道案件では、インドネシア政府が手のひら返し中国案に鞍替えし、日本を袖にしたのは記憶に新しいところですが、南シナ海の南方にあるナトゥナ諸島周辺の排他的経済水域(EEZ)は、中国が主権を主張する「九段線」と呼ばれる境界と重複しており、中国漁船が公船を伴って活動する違法漁業問題で中国と対立しています。

大統領選挙で考えたギャップにハマるということ 5

ギャップにキュンとするというのは人間の本能みたいなもので、ジョコウィの私利私欲のない素朴なおじさん像と、その実強力なリーダーシップを発揮する実務派という内面が、一見普通の人だが実はスゴイというギャップ好きのインドネシア人に大ウケして、大衆は一種の集団催眠状態にあるようです。

情報の質のレベル 6

見える化された結果を共有化することで問題点が共通認識されますが、共有化が進むことで情報の持つ希少価値が薄れて困る人間がいる場合、有益な情報を独占することでポジションを高めようという政治力が働きます。

7

日本人がインドネシアに来ると、インドネシア人ののんびり加減にイライラするというのは昔からよく聞く話で、インドネシア在住日本人にとってのバイブル的小説である深田祐介著「ガルーダ商人」の中でも、インドネシア宗教省の高官が日本人とインドネシア人を自宅に招待する際に、インドネシア人向けの招待状には、遅刻することを前提にパーティ開始時間を三十分早く書いておくという記述があるほどです。

宗教によって異なる「死んだらどうなる」の考え方 8

キリスト教もイスラム教もともにユダヤ教から派生した宗教であり、それぞれイエス・キリスト(本人が神)またはアッラーという唯一無二の神を信じます。

株価操作なんてインドネシア株では当たり前 9

株価は売り注文と買い注文により変動し、大量の売り注文を買う注文がたくさん入れば、他の投資家達は「俺も俺も」と続くことで株価が上がります。

心臓に毛が生えたインドネシア人のずうずうしい転職活動を応援してみた 10

インドネシア人は秘密の話は誰かに暴露しないと精神の安定を保てない人が多いため、内緒の話に情報の希少性は少なく信憑性も低いことが多いので、「ここだけの話」という枕詞付きで聞かされる話は話半分に聞いておいたほうがいいかもしれません。

日系企業のインドネシアでの存在意義 11

今のまま日本の人口減が続けば、内需は縮小の一途をたどるわけで、そうなると日本国内市場だけで生き残るのは難しいと判断する国内企業が、海外市場に活路を見出そうとするのは必然です。

チャンスはあるが勝てる分野を見つけるのが難しい 12

実際にインドネシアに住んでみて、自分で動いて人と話しをして、現地の事情を少しずつ理解していくにつれて、インドネシアで起業することが意外と手強いことに気づき、その難しさの原因は、高い送料と関税であったりローカル企業との競争であったり、就労ビザ(IMTA)や外国人技能開発基金(DPKK)などのランニングコストの高さであったりします。

インドネシアのシステムインテグレーション業界 13

先日JETRO(日本貿易振興機構)さんと、インドネシアの中小企業のIT投資について意見交換させていただく機会をいただいたのですが、そこで「システム投資のコストメリットはどのように説明できるのか」という、システムインテグレーターの存在価値にも関わる重要な問題提起がありました。

肉体と精神と心と魂 14

「Body and Soul」といえば、昨日の内閣改造に伴う人事で内閣府政務官に内定した自民党の今井絵理子参議院員がメンバーだったSPEEDのデビュー曲であり、インドネシアの老舗女性ファッションブランド名でもあります。

ジャカルタのラーメン市場 15

僕がインドネシアに初めて来たのが1997年10月、インドネシア語は分からないし、仕事は辛いし、周囲の人間は理不尽だし、一時期日本に帰りたくて仕方がない時期がありましたが、当時自分をかろうじてインドネシアに繋ぎ止める心の支えとなっていたのが、協栄プリンスビル(今のWisma Keiai)の日本食レストラン「五右衛門」であり、ここでキムチラーメンを食べることが唯一の楽しみと言っても過言ではありませんでした。

ブランド力、技術力、資金力の3要素 16

1998年のジャカルタ暴動後、ルピアが暴落し海外からのドル建て債務を抱えた国内企業が利子の支払いに苦しんでいた頃、僕は外貨が獲得できるインドネシアでの新しいビジネスを探していました。

日本とインドネシアの間でのタイムマシン経営が通じなくなっている件 17

先進国と後進国との間にある流行のタイムラグを利用して、先進国での成功例を後進国で実践するビジネスモデルをタイムマシン経営といいますが、インターネットの普及に伴い情報がフラット化してしまい、モノと情報のタイムラグが限りなく小さくなった今、先駆者である中小零細同業他社が乱立し市場が出来上がったところに、後発の大手が参入し先発零細を駆逐していく、という典型的な負けパターンにはまります。

サリナデパートとマクドナルド 18

本日5月10日を最後にインドネシアのマクドナルド第1号店であるサリナデパート店(Sarinah)が閉店になりますが、ジャカルタのショッピングモールが新しいコンセプトでモダンにリニューアルされ続ける中で、僕がインドネシアに来たばかりの20数年前には、若者の待ち合わせ場所の定番でもあったサリナデパートやブロックMのパサラヤ(Pasaraya)などは完全に時代に取り残されてしまいました。

不景気の歴史 19

僕がインドネシアに来てからこれまで何度か経済不況を見てきましたが、今回の新型コロナウィルスの感染拡大により、間違いなく景気後退しますので、数年後にはこれがコロナショックとかコロナ不況とか呼ばれるようになるのかもしれません。

日本のバブル経済崩壊後とインドネシアの通貨危機後 20

自分が大学に入学したのがバブル経済末期の1991年、土地も株価もMAX爆上げして、三菱地所がアメリカの象徴であるロックフェラーセンタービルを買収し、ジュリアナ東京でワンレンボディコン(登美丘高校ダンス部のバブリーダンスみたいなやつ)のお姉さん達が扇子振って踊っている時期でした。

内需と外需の自国経済に及ぼす影響 21

公共事業投資を行っても、お金が企業内や個人の貯蓄に滞留してしまい国内消費が増えないのが日本の状況であり、国内消費は増えても消費材の輸入品比率が高く、国内資産が海外に流出しているのがインドネシアの状況です。

2019年の総選挙を前にインドネシア政治史のおさらい 22

来年の大統領選挙(Pemilu Pilpres Pileg Indonesia 2019)に向けての選挙運動(Kampanye)を解禁するにあたり、投票用紙に印字される順番はジョコウィ現職大統領・マフル副大統領候補組が1番、プラボウォ大統領候補・サンディアガウノ副大統領候補組が2番と決まりました。

コーヒーをもっと楽しくもっと美味しく 23

インドネシアは北回帰線と南回帰線をはさむコーヒーベルトに位置するコーヒー栽培に適した国で、1602年の東インド会社の進出を契機にオランダの植民地支配が300年以上続き、その間アラビカ種のコーヒーが持ち込まれ、気候のいい高原地帯で栽培が開始されました。

インドネシア人の悪魔祓い 24

人間誰しも自分の中に悪魔が潜んでおり、それが何らかのきっかけで表面に出て来るという考え方自体には、背景に宗教が有るか無いかの違いだけで、基本的に理解できる話であり、それを信じるか信じないかは別として、そういう考えがあることを認めることは大切なことだと思います。

-WEBサイト作成

© 2020 バテラハイシステム Powered by STINGER