Zend_Validate-Db.xml 8.2 KB

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