7
8

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

FileMakerAdvent Calendar 2016

Day 9

FileMaker API for PHP を初めて触る人のために

Last updated at Posted at 2016-12-08

初めての FileMaker API for PHP

FileMaker API を用いようとする動機は様々だと思います。Webアプリケーションを本格的に作成したり、そこまでいかなくても簡単な Webベースのシステムを作ったりといったところでしょうか。

いずれにしてもデータベースの操作における CRUD のうち、メインになるのは R(Read)だと思います。ここでは全ての基礎となる Read の方法に絞って説明をします。

Read のための下準備(PHP のコード)

まずは昨日の記事のとおりに FileMaker API for PHP のライブラリをインストール(コピー)します。そのコピーしたディレクトリのルートにあるFileMaker.phprequireしましょう。

fmapi_first_trial.php
<?php
require_once("./lib/FileMaker.php"); # lib/ に展開した場合

次に、FileMaker Server のアドレスと、ログイン情報を以下のように定義します。

fmapi_first_trial.php
$DB_HOST = "FileMaker Server のアドレス";
$DB_USER = "ユーザ名";
$DB_PASS = "ユーザ名に対するパスワード";

そして用いるデータベースの名前(レイアウトの名前ではないです)をさらに定義しましょう。

fmapi_first_trial.php
$DB_NAME = "データベースの名前";

ここまでで下準備は完了です。

FileMakerクラスのインスタンスを作成し、レイアウトを確定する

上記に設定した定数を用いて、FileMakerクラスのインスタンスを作成しましょう。定数(引数)の順番に注意です。

fmapi_first_trial.php
$fm_instance = new FileMaker($DB_NAME, $DB_HOST, $DB_USER, $DB_PASS);

このインスタンスに対して、対象とする「レイアウト」を指定し、その返り値を$find_procに入れましょう。

fmapi_first_trial.php
$find_proc = $fm_instance->newFindCommand("レイアウト名");

検索条件を書いていこう

いよいよレコードの検索部分を書いていきます。上記で生成した$find_procに対し、addFindCriterionというメソッドを実行します。

第一引数が「対象フィールド」、第二引数が「検索条件」です。ここで「検索条件」は FileMaker における検索条件の書式と同じものを用います。以下がサンプルコードです。

fmapi_first_trial.php
$find_proc->addFindCriterion("対象フィールド", "==apple");

検索を実行する

これで検索条件がセットされました。まだ検索自体は行われていませんので、execute()メソッドを用いて検索を行います。

fmapi_first_trial.php
$find_result = $find_proc->execute();

無事、検索が実行され、その結果が$find_resultに入りました。

エラー処理

検索結果を早く見たいところですが、一般的に何らかの「実行」後にはエラー処理(チェック)を忘れてはいけません。FileMaker API for PHP でのエラー処理は定型化していますので、以下のように書きましょう。

fmapi_first_trial.php
if (FileMaker::isError($find_result)) {
    # エラーの場合
    echo "FileMaker Error Code: " . $find_result->getCode(). "\n";
    echo "FileMaker Error Message: " . $find_result->getMessage() . "\n";
} else {
    # 正常に実行された場合
    $result_records = $find_result->getRecords();
}

これでエラーの場合はエラーコードとエラーメッセージが表示されます。正常に実行された場合は$find_resultgetRecords()メソッドを実行しています。$find_resultのままだとデータが広大で扱いにくいため、$find_resultの中からレコードに関するデータだけを抽出するためにgetRecords()メソッドを使って絞り込み、$result_recordsに格納しています。

得られたレコードを扱う

上記で得られた$result_recordsは配列です。検索の結果、複数のレコードが引っかかるからです1。したがって、$result_recordsに対して何らかの操作をする場合はforeachをするのが定石でしょう。

なお、$result_records[index]に対して使える主なメソッドとしては以下のようなものがあります。

  • $result_records[index]->getField(フィールド名)
    • 対象となるレコードの「フィールド名」に指定されたフィールドの値を取得する
  • $result_record[index]->getRecordId()
    • 対象となるレコードの「レコードID」を取得する

他にもいろいろなメソッドがありますので調べてみてください。

具体例

ここで具体的な例を見てみましょう。

利用するデータベース

まずは具体例に利用するデータベースが必要です。以下のようにStaffというデータベースのStaffDataレイアウト内のstaff_dataというテーブルを用います2

fm_Qiita_02.png

fm_Qiita_03.png

以下の5つのカラムが定義されているのが分かります。

  • id
  • name
  • gender
  • work
  • point

このテーブルに対して 7 つのデータが投入されています。

コードを書く

これまでに書いた内容をまとめて、以下のような検索条件で検索をしてみましょう。

genderfemaleであるレコード

以下がコードになります。

find_record_for_gender_female_fmapi.php
<?php
require_once("./lib/FileMaker.php"); # lib/ に展開した場合

$DB_HOST = "FileMaker Server のアドレス";
$DB_USER = "ユーザ名";
$DB_PASS = "ユーザ名に対するパスワード";
$DB_NAME = "Staff";
$fm_instance = new FileMaker($DB_NAME, $DB_HOST, $DB_USER, $DB_PASS);

$find_proc = $fm_instance->newFindCommand("StaffData");
$find_proc->addFindCriterion("gender", "==female");
$find_result = $find_proc->execute();

if (FileMaker::isError($find_result)) {
    # エラーの場合
    echo "FileMaker Error Code: " . $find_result->getCode(). "\n";
    echo "FileMaker Error Message: " . $find_result->getMessage() . "\n";
} else {
    # 正常に実行された場合
    $result_records = $find_result->getRecords();
}

# 検索結果の表示
echo count($result_records) . " 件ヒットしました!" . "\n\n";
echo "ヒットした方のお名前は以下のとおりです" . "\n";
foreach ($result_records as $result_record) {
    echo $result_record->getField("name") . "\n";
}
結果
3 件ヒットしました!

ヒットした方のお名前は以下のとおりです
higashino
ishikawa
kawano

まとめ

極めて簡単でしたが FileMaker API for PHP を使う方法を記してみました。マイナビのサイトなどを見るとより多くのメソッドや応用例が載っていますので、上記を参考にして自由にレコードを操作してみてください。

  1. もちろんレコードが一つだけ引っかかる場合もありますが

  2. いろいろ問題がある設計ですが、あくまでサンプルとして分かりやすさを重視しています

7
8
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
7
8

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?