Zend_Validate-Db.xml 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 18417 -->
  4. <sect2 id="zend.validate.Db">
  5. <title>Db_RecordExists および Db_NoRecordExists</title>
  6. <para>
  7. <classname>Zend_Validate_Db_RecordExists</classname> および
  8. <classname>Zend_Validate_Db_NoRecordExists</classname> は、
  9. データベースのテーブル上に
  10. 指定した値のレコードが存在するかどうかを調べる手段を提供します。
  11. </para>
  12. <sect3 id="zend.validate.db.basic-usage">
  13. <title>基本的な使用法</title>
  14. <para>
  15. このバリデータの基本的な使用例です。
  16. </para>
  17. <programlisting language="php"><![CDATA[
  18. // メールアドレスがデータベース内に存在するかどうかを調べます
  19. $validator = new Zend_Validate_Db_RecordExists(
  20. array(
  21. 'table' => 'users',
  22. 'field' => 'emailaddress'
  23. )
  24. );
  25. if ($validator->isValid($emailaddress)) {
  26. // メールアドレスは有効なようです
  27. } else {
  28. // メールアドレスが無効なので、その理由を表示します
  29. foreach ($validator->getMessages() as $message) {
  30. echo "$message\n";
  31. }
  32. }
  33. ]]></programlisting>
  34. <para>
  35. 上の例は、指定したメールアドレスがデータベースのテーブル内に存在するかどうかを調べます。
  36. 指定したカラムの値が <varname>$emailaddress</varname> に一致するレコードがなければ、
  37. エラーメッセージが表示されます。
  38. </para>
  39. <programlisting language="php"><![CDATA[
  40. // ユーザ名がデータベースに存在しないことを調べます
  41. $validator = new Zend_Validate_Db_NoRecordExists(
  42. array(
  43. 'table' => 'users',
  44. 'field' => 'username'
  45. )
  46. );
  47. if ($validator->isValid($username)) {
  48. // ユーザ名は有効なようです
  49. } else {
  50. // ユーザ名が無効なので、その理由を表示します
  51. $messages = $validator->getMessages();
  52. foreach ($messages as $message) {
  53. echo "$message\n";
  54. }
  55. }
  56. ]]></programlisting>
  57. <para>
  58. 上の例は、指定したユーザ名がデータベースのテーブル上に存在しないことを確認します。
  59. 指定したカラムの値が <varname>$username</varname> に一致するレコードが見つかれば、
  60. エラーメッセージが表示されます。
  61. </para>
  62. </sect3>
  63. <sect3 id="zend.validate.db.excluding-records">
  64. <title>レコードの除外</title>
  65. <para>
  66. <classname>Zend_Validate_Db_RecordExists</classname> および
  67. <classname>Zend_Validate_Db_NoRecordExists</classname> には、
  68. テーブルの一部を除外してその内容を調べる方法があります。
  69. where 句を文字列で指定するか、あるいはキー
  70. "field" および "value" を含む配列を指定します。
  71. </para>
  72. <para>
  73. 除外条件を配列で指定すると、<code>!=</code> 演算子を使用します。
  74. つまり、テーブル内の残りのレコードの内容を確認してからレコードを変更できるのです
  75. (たとえばユーザ情報のフォームなどで使用します)。
  76. </para>
  77. <programlisting language="php"><![CDATA[
  78. // そのユーザ名のユーザがほかにいないことを調べます
  79. $user_id = $user->getId();
  80. $validator = new Zend_Validate_Db_NoRecordExists(
  81. array(
  82. 'table' => 'users',
  83. 'field' => 'username',
  84. 'exclude' => array(
  85. 'field' => 'id',
  86. 'value' => $user_id
  87. )
  88. )
  89. );
  90. if ($validator->isValid($username)) {
  91. // ユーザ名は有効なようです
  92. } else {
  93. // ユーザ名が無効なので、その理由を表示します
  94. $messages = $validator->getMessages();
  95. foreach ($messages as $message) {
  96. echo "$message\n";
  97. }
  98. }
  99. ]]></programlisting>
  100. <para>
  101. 上の例は、<code>id = $user_id</code>
  102. であるレコードを除いてそのテーブル内に $username
  103. を含むレコードが存在しないことを調べます。
  104. </para>
  105. <para>
  106. 除外条件を文字列で指定することもできるので、
  107. <code>!=</code> 以外の演算子を指定することもできます。
  108. これは、複合キーに対するチェックの際に便利です。
  109. </para>
  110. <programlisting language="php"><![CDATA[
  111. $post_id = $post->getId();
  112. $clause = $db->quoteInto('post_id = ?', $category_id);
  113. $validator = new Zend_Validate_Db_RecordExists(
  114. array(
  115. 'table' => 'posts_categories',
  116. 'field' => 'post_id',
  117. 'exclude' => $clause
  118. )
  119. );
  120. if ($validator->isValid($username)) {
  121. // ユーザ名は有効なようです
  122. } else {
  123. // ユーザ名が無効なので、その理由を表示します
  124. $messages = $validator->getMessages();
  125. foreach ($messages as $message) {
  126. echo "$message\n";
  127. }
  128. }
  129. ]]></programlisting>
  130. <para>
  131. 上の例は、<code>posts_categories</code> テーブル内に
  132. <code>post_id</code> の値が
  133. <varname>$category_id</varname> に一致するレコードがあることを調べます。
  134. </para>
  135. </sect3>
  136. <sect3 id="zend.validate.db.database-adapters">
  137. <title>データベースアダプタ</title>
  138. <para>
  139. アダプタを指定することもできます。
  140. 複数のデータベースアダプタを使用している場合や
  141. デフォルトのアダプタを設定していない場合などにこれを使用します。
  142. 以下に例を示します。
  143. </para>
  144. <programlisting language="php"><![CDATA[
  145. $validator = new Zend_Validate_Db_RecordExists(
  146. array(
  147. 'table' => 'users',
  148. 'field' => 'id',
  149. 'adapter' => $dbAdapter
  150. )
  151. );
  152. ]]></programlisting>
  153. </sect3>
  154. <sect3 id="zend.validate.db.database-schemas">
  155. <title>データベーススキーマ</title>
  156. <para>
  157. データベース内のスキーマを
  158. PostgreSQL や DB/2 のアダプタで指定するには、キー
  159. <code>table</code> および <code>schema</code> を持つ配列を次の例のように渡します。
  160. below:
  161. </para>
  162. <programlisting language="php"><![CDATA[
  163. $validator = new Zend_Validate_Db_RecordExists(
  164. array(
  165. 'table' => 'users',
  166. 'schema' => 'my',
  167. 'field' => 'id'
  168. )
  169. );
  170. ]]></programlisting>
  171. </sect3>
  172. </sect2>