maxdb_stmt_execute
(PECL)
maxdb_stmt_execute
(no version information, might be only in CVS)
stmt->execute -- プリペアドクエリを実行する
説明
手続き型
bool
maxdb_stmt_execute ( resource stmt )
オブジェクト指向型 (メソッド)
class
stmt {
bool
execute ( void )
}
maxdb_stmt_execute() 関数は、
stmt で表される、事前に maxdb_prepare()
で準備したクエリを実行します。実行の際には、
すべてのパラメータマーカが適切な値に置き換えられます。
UPDATE、DELETE あるいは INSERT 文の場合は、
maxdb_stmt_affected_rows() 関数を使用すると
変更された行の総数が取得できます。同じく、
結果セットを返すクエリの場合は maxdb_fetch()
関数を使用して結果を取得できます。
注意:
maxdb_stmt_execute() を使用する際は、
他のクエリを実行する前に必ず maxdb_fetch()
でデータを取得しなければなりません。
返り値
成功した場合に TRUE を、失敗した場合に FALSE を返します。
例
例 1. オブジェクト指向型
<?php $maxdb = new maxdb("localhost", "MONA", "RED", "DEMODB"); /* 接続を調べます */ if (maxdb_connect_errno()) { printf("接続に失敗しました: %s\n", maxdb_connect_error()); exit(); } $maxdb->query("CREATE TABLE temp.mycity LIKE hotel.city"); /* insert 文を準備します */ $query = "INSERT INTO temp.mycity (zip, name, state) VALUES (?,?,?)"; $stmt = $maxdb->prepare($query);
$stmt->bind_param("sss", $val1, $val2, $val3);
$val1 = '11111'; $val2 = 'Georgetown'; $val3 = 'NY'; /* ステートメントを実行します */ $stmt->execute();
$val1 = '22222'; $val2 = 'Hubbatown'; $val3 = 'CA'; /* ステートメントを実行します */ $stmt->execute();
/* ステートメントを閉じます */ $stmt->close();
/* myCity からすべての行を取得します */ $query = "SELECT zip, name, state FROM temp.mycity"; if ($result = $maxdb->query($query)) { while ($row = $result->fetch_row()) { printf("%s (%s,%s)\n", $row[0], $row[1], $row[2]); } /* 結果セットを開放します */ $result->close(); }
/* テーブルを削除します */ $maxdb->query("DROP TABLE temp.mycity");
/* 接続を閉じます */ $maxdb->close(); ?>
|
|
例 2. 手続き型
<?php $link = maxdb_connect("localhost", "MONA", "RED", "DEMODB"); /* 接続を調べます */ if (maxdb_connect_errno()) { printf("接続に失敗しました: %s\n", maxdb_connect_error()); exit(); } maxdb_query($link, "CREATE TABLE temp.mycity LIKE hotel.city"); /* insert 文を準備します */ $query = "INSERT INTO temp.mycity (zip, name, state) VALUES (?,?,?)"; $stmt = maxdb_prepare($link, $query);
maxdb_stmt_bind_param($stmt, "sss", $val1, $val2, $val3);
$val1 = '11111'; $val2 = 'Georgetown'; $val3 = 'NY'; /* ステートメントを実行します */ maxdb_stmt_execute($stmt);
$val1 = '22222'; $val2 = 'Hubbatown'; $val3 = 'CA'; /* ステートメントを実行します */ maxdb_stmt_execute($stmt);
/* ステートメントを閉じます */ maxdb_stmt_close($stmt);
/* myCity からすべての行を取得します */ $query = "SELECT zip, name, state FROM temp.mycity"; if ($result = maxdb_query($link, $query)) { while ($row = maxdb_fetch_row($result)) { printf("%s (%s,%s)\n", $row[0], $row[1], $row[2]); } /* 結果セットを開放します */ maxdb_free_result($result); }
/* テーブルを削除します */ maxdb_query($link, "DROP TABLE temp.mycity");
/* 接続を閉じます */ maxdb_close($link); ?>
|
|
上の例の出力は、たとえば以下のようになります。
11111 (Georgetown,NY)
22222 (Hubbatown,CA) |