Zend_Db_Select.xml 57 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15103 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.db.select">
  5. <title>Zend_Db_Select</title>
  6. <sect2 id="zend.db.select.introduction">
  7. <title>Descripción del Objeto Select</title>
  8. <para>
  9. El objeto Zend_Db_Select object representa una declaración de consulta
  10. <code>SELECT</code> de SQL. La clase tiene métodos para agregar partes
  11. individuales a la consulta. Se pueden especificar algunas partes de la consulta
  12. usando los métodos en PHP y sus estructuras de datos, y la clase forma la sintaxis
  13. SLQ correcta. Después de construir la consulta, puede ejecutarla como si
  14. se hubiera escrito como un string.
  15. </para>
  16. <para>
  17. Las posibilidades de <classname>Zend_Db_Select</classname> incluyen:
  18. </para>
  19. <itemizedlist>
  20. <listitem>
  21. <para>
  22. Métodos Orientados a objetos para especificar consultas SQL
  23. pieza-a-pieza;
  24. </para>
  25. </listitem>
  26. <listitem>
  27. <para>
  28. Abstracción de partes de las consultas SQL, independiente de la
  29. Base de datos;
  30. </para>
  31. </listitem>
  32. <listitem>
  33. <para>
  34. Entrecomillado automático de identificadores de metadatos en
  35. la mayoría de los casos, soportanto identificadores que contienen palabras
  36. reservadas de SQL y caracteres especiales;
  37. </para>
  38. </listitem>
  39. <listitem>
  40. <para>
  41. Entrecomillado de identificadores y valores, para ayudar a reducir el
  42. riesgo de ataque por inyección SQL.
  43. </para>
  44. </listitem>
  45. </itemizedlist>
  46. <para>
  47. El uso de <classname>Zend_Db_Select</classname> no es obligatorio. Para consultas SELECT muy simples,
  48. es usualmente más simple especificar la consulta completa como un string
  49. y ejecutarla usando un método del Adapter como <code>query()</code> o
  50. <code>fetchAll()</code>. Usar <classname>Zend_Db_Select</classname> es útil si se necesita ensamblar
  51. una consulta SELECT proceduralmente, o basada en condiciones lógicas en
  52. la aplicación.
  53. </para>
  54. </sect2>
  55. <sect2 id="zend.db.select.creating">
  56. <title>Creando un Objeto Select</title>
  57. <para>
  58. Se puede crear una instancia del objeto <classname>Zend_Db_Select</classname> usando el método
  59. <code>select()</code> de un objeto <classname>Zend_Db_Adapter_Abstract</classname>.
  60. </para>
  61. <example id="zend.db.select.creating.example-db">
  62. <title>Ejemplo del método select() del adaptador</title>
  63. <programlisting role="php"><![CDATA[
  64. $db = Zend_Db::factory( ...options... );
  65. $select = $db->select();
  66. ]]></programlisting>
  67. </example>
  68. <para>
  69. Otra manera de crear el objeto <classname>Zend_Db_Select</classname> es con su constructor,
  70. especificando el adaptador de base de datos como un argumento.
  71. </para>
  72. <example id="zend.db.select.creating.example-new">
  73. <title>Ejemplo de creación de un nuevo objeto Select</title>
  74. <programlisting role="php"><![CDATA[
  75. $db = Zend_Db::factory( ...options... );
  76. $select = new Zend_Db_Select($db);
  77. ]]></programlisting>
  78. </example>
  79. </sect2>
  80. <sect2 id="zend.db.select.building">
  81. <title>Construyendo consultas Select</title>
  82. <para>Cuando se construye una consulta, puede agregar cláusulas a ésta, una por una.
  83. Hay un método separado para agregar cada una al objeto <classname>Zend_Db_Select</classname>.</para>
  84. <example id="zend.db.select.building.example">
  85. <title>Ejemplo de uso de métodos que agregan cláusulas</title>
  86. <programlisting role="php"><![CDATA[
  87. // Crear el objeto Zend_Db_Select
  88. $select = $db->select();
  89. // Agregar una cláusula FROM
  90. $select->from( ...specify table and columns... )
  91. // Agregar una cláusula WHERE
  92. $select->where( ...specify search criteria... )
  93. // Agregar una cláusula ORDER BY
  94. $select->order( ...specify sorting criteria... );
  95. ]]></programlisting>
  96. </example>
  97. <para>También puede utilizar la mayoría de los métodos del objeto <classname>Zend_Db_Select</classname> con una
  98. interfaz fluida. Una interfaz fluida significa que cada método devuelve una referencia
  99. al objeto que se ha llamado, así se puede llamar inmediatamente a otro método.</para>
  100. <example id="zend.db.select.building.example-fluent">
  101. <title>Ejemplo de uso de la interfaz fluida.</title>
  102. <programlisting role="php"><![CDATA[
  103. $select = $db->select()
  104. ->from( ...specify table and columns... )
  105. ->where( ...specify search criteria... )
  106. ->order( ...specify sorting criteria... );
  107. ]]></programlisting>
  108. </example>
  109. <para>Los ejemplos en esta sección muestran el uso de la interfaz fluída, pero también
  110. se puede usar la interfaz no-fluída en todos los casos. A menudo es necesario
  111. utilizar la interfaz no-fluída, por ejemplo, si su aplicación necesita realizar
  112. cierta lógica antes de añadir una cláusula a la consulta.</para>
  113. <sect3 id="zend.db.select.building.from">
  114. <title>Agregando una cláusula FROM</title>
  115. <para>
  116. Especifique la tabla para esta consulta usando el método <code>from()</code>.
  117. Se puede especificar el nombre de la tabla como un string. <classname>Zend_Db_Select</classname>
  118. aplica el identificador entrecomillando el nombre de la tabla, así puede
  119. utilizar caracteres especiales.
  120. </para>
  121. <example id="zend.db.select.building.from.example">
  122. <title>Ejemplo del método from()</title>
  123. <programlisting role="php"><![CDATA[
  124. // Construye la consulta:
  125. // SELECT *
  126. // FROM "products"
  127. $select = $db->select()
  128. ->from( 'products' );
  129. ]]></programlisting>
  130. </example>
  131. <para>
  132. Puede especificar un nombre de correlación (también llamado a veces
  133. "alias de tabla") para una tabla. En lugar de un string, se usa un
  134. array asociativo que mapee el nombre de correlación con el nombre de la tabla.
  135. En otras cláusulas de consulta SQL, utilice nombre de correlación.
  136. Si su consulta se une con más de una tabla, <classname>Zend_Db_Select</classname> genera una
  137. correlación unica de nombres basados en el nombre de la tabla, para una tabla
  138. a la cual no se le espicifique un nombre de correlación.
  139. </para>
  140. <example id="zend.db.select.building.from.example-cname">
  141. <title>Ejemplo especificando una tabla con nombre de correlación</title>
  142. <programlisting role="php"><![CDATA[
  143. // Construya esta consulta:
  144. // SELECT p.*
  145. // FROM "products" AS p
  146. $select = $db->select()
  147. ->from( array('p' => 'products') );
  148. ]]></programlisting>
  149. </example>
  150. <para>
  151. Algunos RDBMS apoyan el uso de un especificador de esquema para una tabla.
  152. Puede especificar el nombre de la tabla como
  153. "<code>nombreDeEsquema.nombre DeTabla</code>", donde <classname>Zend_Db_Select</classname> entrecomillará
  154. cada parte individualmente, o tambien puedes especificar el nombre de esquema
  155. por separado. Un nombre de esquema especificado en el nombre de la tabla toma
  156. precedencia en sobre un esquema dado por separado en el caso de que ambos
  157. sean dados.
  158. </para>
  159. <example id="zend.db.select.building.from.example-schema">
  160. <title>Ejemplo especificando un nombre de esquema</title>
  161. <programlisting role="php"><![CDATA[
  162. // Construya esta consulta:
  163. // SELECT *
  164. // FROM "myschema"."products"
  165. $select = $db->select()
  166. ->from( 'myschema.products' );
  167. // o
  168. $select = $db->select()
  169. ->from('products', '*', 'myschema');
  170. ]]></programlisting>
  171. </example>
  172. </sect3>
  173. <sect3 id="zend.db.select.building.columns">
  174. <title>Agregando Columnas</title>
  175. <para>
  176. En el segundo argumento del método <code>from()</code>, puede especificar
  177. las columnas que seleccionar desde la tabla respectiva.
  178. Si no especifica columnas, por defecto será "<code>*</code>",
  179. el comodín SQL para "todas las columnas".
  180. </para>
  181. <para>
  182. Puede listar las columnas en un simple array de strings, o en un
  183. array asociativo mapeando los alias de columnas a su nombre de tabla.
  184. Si solo se especifica una columna en la consulta y no necesita especificar un
  185. alias de columna, puede listarla solo con un string en lugar de un array.
  186. </para>
  187. <para>
  188. Si se entrega un array vacío como el argumento de las tablas, no se incluirán
  189. columnas en el resultado. Vea un
  190. <link linkend="zend.db.select.building.join.example-no-columns">código de ejemplo</link>
  191. en la sección del método <code>join()</code>.
  192. </para>
  193. <para>
  194. Puedes especificar el nombre de columna como
  195. "<code>nombreCorrelacionado.nombreDeColumna</code>".
  196. <classname>Zend_Db_Select</classname> entrecomillará cada parte individualmente. Si no especifica
  197. un nombre de correlación para una columna, se usará el nombre de correlación
  198. para la tabla nombrada en el método actual <code>from()</code>.
  199. </para>
  200. <example id="zend.db.select.building.columns.example">
  201. <title>Ejemplos especificando columnas</title>
  202. <programlisting role="php"><![CDATA[
  203. // Construir esta consulta:
  204. // SELECT p."product_id", p."product_name"
  205. // FROM "products" AS p
  206. $select = $db->select()
  207. ->from(array('p' => 'products'),
  208. array('product_id', 'product_name'));
  209. // Construir la misma consulta, especificando nombres de correlación
  210. // SELECT p."product_id", p."product_name"
  211. // FROM "products" AS p
  212. $select = $db->select()
  213. ->from(array('p' => 'products'),
  214. array('p.product_id', 'p.product_name'));
  215. // Construir esta consulta con una alias para una columna:
  216. // SELECT p."product_id" AS prodno, p."product_name"
  217. // FROM "products" AS p
  218. $select = $db->select()
  219. ->from(array('p' => 'products'),
  220. array('prodno' => 'product_id', 'product_name'));
  221. ]]></programlisting>
  222. </example>
  223. </sect3>
  224. <sect3 id="zend.db.select.building.columns-expr">
  225. <title>Agregando una Expresión en las Columns</title>
  226. <para>
  227. Las columnas en consultas SQL a veces son expresiones, no simples columnas
  228. de una tabla. Las expresiones no deberían tener nombres de correlación o entrecomillado aplicado.
  229. Si sus columnas contienen paréntesis, <classname>Zend_Db_Select</classname> las reconoce como una expresión.
  230. </para>
  231. <para>
  232. Tambien puede crear un objeto de tipo <classname>Zend_Db_Expr</classname> explícitamente, para prevenir
  233. que el string sea tratado como columna. <classname>Zend_Db_Expr</classname> es una clase mínima, que contiene
  234. un simple string. <classname>Zend_Db_Select</classname> reconoce el objeto de tipo <classname>Zend_Db_Expr</classname> y
  235. lo convierte de vuelta en el string, pero no le aplica ninguna alteración,
  236. tal como el entrecomillado o la correlación de nombres.
  237. </para>
  238. <note>
  239. <para>
  240. El Uso de <classname>Zend_Db_Expr</classname> para nombres de columnas no es necesario si
  241. la expresión de la columna contiene paréntesis; <classname>Zend_Db_Select</classname> reconoce
  242. y trata el string como expresión, saltándose el entrecomillado y la
  243. correlación de nombres.
  244. </para>
  245. </note>
  246. <example id="zend.db.select.building.columns-expr.example">
  247. <title>Ejemplos especificando columnas que contienen expresiones</title>
  248. <programlisting role="php"><![CDATA[
  249. // Construya esta consulta:
  250. // SELECT p."product_id", LOWER(product_name)
  251. // FROM "products" AS p
  252. // Una expresion con parentesis implicitamente se transforma en
  253. // un Zend_Db_Expr.
  254. $select = $db->select()
  255. ->from(array('p' => 'products'),
  256. array('product_id', 'LOWER(product_name)'));
  257. // Construya esta consulta:
  258. // SELECT p."product_id", (p.cost * 1.08) AS cost_plus_tax
  259. // FROM "products" AS p
  260. $select = $db->select()
  261. ->from(array('p' => 'products'),
  262. array('product_id',
  263. 'cost_plus_tax' => '(p.cost * 1.08)')
  264. );
  265. // Construya esta consulta usando Zend_Db_Expr explícitamente:
  266. // SELECT p."product_id", p.cost * 1.08 AS cost_plus_tax
  267. // FROM "products" AS p
  268. $select = $db->select()
  269. ->from(array('p' => 'products'),
  270. array('product_id',
  271. 'cost_plus_tax' =>
  272. new Zend_Db_Expr('p.cost * 1.08'))
  273. );
  274. ]]></programlisting>
  275. </example>
  276. <para>
  277. En los casos anteriores, <classname>Zend_Db_Select</classname> no altera el string para aplicar
  278. correlación de nombres o entrecomillado de identificadores. Si estos
  279. cambios son necesarios para resolver ambigüedades, deberías realizar
  280. cambios manualmente en el string.
  281. </para>
  282. <para>
  283. Si el nombre de su columna es alguna palabra reservada de SQL o
  284. contiene caracteres especiales, debería usar el método
  285. <code>quoteIdentifier()</code> del Adapdator e interpolar el resultado en un
  286. string. El método <code>quoteIdentifier()</code> usa entrecomillado SQL para
  287. delimitar el identificador,
  288. the identifier, dejando en claro que es un identificador de tabla o columna y no
  289. otra parte de la sintaxis SQL.
  290. </para>
  291. <para>
  292. Su código es más independiente de la base de datos si se usa el método
  293. <code>quoteIdentifier()</code> en vez de las excribir literalmente las comillas
  294. en la cadena, debido a que algunos RDBMS no usan simbolos estándar para entrecomillar
  295. identificadores.
  296. El método <code>quoteIdentifier()</code> está diseñado para usar los símbolos
  297. apropiados para entrecomillar basado en el tipo del adaptador.
  298. El método <code>quoteIdentifier()</code> también escapa
  299. cual caracter de comilla que aparezca en el nombre del identificador mismo.
  300. </para>
  301. <example id="zend.db.select.building.columns-quoteid.example">
  302. <title>Ejemplo de entrecomillado de columnas en una expresión</title>
  303. <programlisting role="php"><![CDATA[
  304. // Construya esta consulta, entrecomillando el nombre
  305. // especial de la columna llamada "from" en la expresión:
  306. // SELECT p."from" + 10 AS origin
  307. // FROM "products" AS p
  308. $select = $db->select()
  309. ->from(array('p' => 'products'),
  310. array('origin' =>
  311. '(p.' . $db->quoteIdentifier('from') . ' + 10)')
  312. );
  313. ]]></programlisting>
  314. </example>
  315. </sect3>
  316. <sect3 id="zend.db.select.building.columns-atomic">
  317. <title>Agregar columnas a una tabla FROM o JOIN existente</title>
  318. <para>
  319. Puede haber casos en los que desea agregar columnas a una tabla FROM o JOIN
  320. después de que estos métodos han sido llamados. El método <code>columns()</code>
  321. permite agregar columnas en cualquier punto antes de ejecutar la consulta.
  322. Puedes pasar las columnas bien como un string, un <classname>Zend_Db_Expr</classname> o
  323. un array de estos elementos. El segundo argumento para este método puede ser omitido,
  324. implicando que las columnas serán agregadas a una tabla FROM, en otro caso
  325. debería usarse un nombre de correlación existente.
  326. </para>
  327. <example id="zend.db.select.building.columns-atomic.example">
  328. <title>Ejemplos agregando columnas con el método<code>columns()</code></title>
  329. <programlisting role="php"><![CDATA[
  330. // Construir la consulta:
  331. // SELECT p."product_id", p."product_name"
  332. // FROM "products" AS p
  333. $select = $db->select()
  334. ->from(array('p' => 'products'), 'product_id')
  335. ->columns('product_name');
  336. // Construir la misma consulta, especificando correlación de nombres:
  337. // SELECT p."product_id", p."product_name"
  338. // FROM "products" AS p
  339. $select = $db->select()
  340. ->from(array('p' => 'products'), 'p.product_id')
  341. ->columns('product_name', 'p');
  342. // Alternativamente puede usar columns('p.product_name')
  343. ]]></programlisting>
  344. </example>
  345. </sect3>
  346. <sect3 id="zend.db.select.building.join">
  347. <title>Agregar Otra Tabla a la Consulta Query con JOIN</title>
  348. <para>
  349. Muchas consultas útiles involucran el uso de un <code>JOIN</code> para
  350. combinar filas de multiples tablas. Puedes agregar tablas a una consulta <classname>Zend_Db_Select</classname>
  351. usando el método <code>join()</code>. Usar este método, es similar
  352. al método <code>from()</code>, excepto que puedes especificar una condición de unión
  353. en la mayoría de los casos.
  354. </para>
  355. <example id="zend.db.select.building.join.example">
  356. <title>Ejemplo del método join()</title>
  357. <programlisting role="php"><![CDATA[
  358. // Construya esta consulta:
  359. // SELECT p."product_id", p."product_name", l.*
  360. // FROM "products" AS p JOIN "line_items" AS l
  361. // ON p.product_id = l.product_id
  362. $select = $db->select()
  363. ->from(array('p' => 'products'),
  364. array('product_id', 'product_name'))
  365. ->join(array('l' => 'line_items'),
  366. 'p.product_id = l.product_id');
  367. ]]></programlisting>
  368. </example>
  369. <para>
  370. El segundo argumento <code>join()</code> es un string que es usado como condición de unión.
  371. Esta es una expresión que declara un criterio por el cual las filas en una tabla concuerdan con
  372. las filas de la otra tabla. Puedes especificar correlación de nombres en esta expresión.
  373. </para>
  374. <note>
  375. <para>
  376. No se aplica entrecomillado en la expresión especificada para la condición de unión;
  377. si tienes problemas con nombres que necesitan ser entrecomillados, deberás usar
  378. <code>quoteIdentifier()</code> para formar el string de condición de unión.
  379. </para>
  380. </note>
  381. <para>
  382. El tercer argumento <code>join()</code> es un array de nombres de columnas, como
  383. al usar el método <code>from()</code>. Este es por defecto "<code>*</code>", soporta
  384. correlación de nombres, expresiones, y <classname>Zend_Db_Expr</classname> de la misma manera que el array de
  385. nombres de columnas en el método <code>from()</code>.
  386. </para>
  387. <para>
  388. Para no seleccionar columnas de una tabla, use un array vacío para la lista de columnas.
  389. El uso de esto trabaja con el método <code>from()</code> también, pero en general
  390. deseará algunas columnas de la tabla primaria en sus consultas, a la vez que no se desean
  391. columnas de la tabla unida.
  392. </para>
  393. <example id="zend.db.select.building.join.example-no-columns">
  394. <title>Ejemplo especificando ninguna columna</title>
  395. <programlisting role="php"><![CDATA[
  396. // Construya esta consulta:
  397. // SELECT p."product_id", p."product_name"
  398. // FROM "products" AS p JOIN "line_items" AS l
  399. // ON p.product_id = l.product_id
  400. $select = $db->select()
  401. ->from(array('p' => 'products'),
  402. array('product_id', 'product_name'))
  403. ->join(array('l' => 'line_items'),
  404. 'p.product_id = l.product_id',
  405. array() ); // empty list of columns
  406. ]]></programlisting>
  407. <para>
  408. Note el array vacío <code>array()</code> en el ejemplo anterior
  409. en lugar de una lista de columnas de la tabla unida.
  410. </para>
  411. </example>
  412. <para>
  413. SQL tiene muchos tipos de uniones. Vea una lista a continuación para los métodos
  414. que soporta cada tipo de unión en <classname>Zend_Db_Select</classname>.
  415. </para>
  416. <itemizedlist>
  417. <listitem>
  418. <para>
  419. <command>INNER JOIN</command> con los métodos
  420. <code>join(table, join, [columns])</code> o
  421. <code>joinInner(table, join, [columns])</code>.
  422. </para>
  423. <para>
  424. Éste es el tipo de unión más comun. Las filas de cada tabla son comparadas
  425. usando la condición de unión especificada. El resultado incluye solo las filas
  426. que satisfacen la condición. El resultado puede ser vacío si no hay filas que
  427. satisfagan la condición.
  428. </para>
  429. <para>
  430. Todos los RDBMS soportan este tipo de unión.
  431. </para>
  432. </listitem>
  433. <listitem>
  434. <para>
  435. <command>LEFT JOIN</command> con el método
  436. <code>joinLeft(table, condition, [columns])</code>.
  437. </para>
  438. <para>
  439. Todas las filas de tabla a la izquierda del operando son incluidas,
  440. pareando las filas de la tabla a la derecha del operando,
  441. y las columnas de la tabla a la derecha del operando son rellenadas con
  442. NULLs si no existen filas que coincidan con la tabla a la izquierda.
  443. </para>
  444. <para>
  445. Todos los RDBMS soportan este tipo de unión.
  446. </para>
  447. </listitem>
  448. <listitem>
  449. <para>
  450. <command>RIGHT JOIN</command> con el método
  451. <code>joinRight(table, condition, [columns])</code>.
  452. </para>
  453. <para>
  454. Unión exterior por la derecha es el complementario de la unión exterior por la
  455. izquierda. Todas las filas de la tabla a la derecha del operando son incluidas,
  456. pareando las filas de la tabla a la izquierda del operando incluidas, y las
  457. columnas de la tabla a la izquierda del operando son rellenadas con NULLs si
  458. no existen filas que coincidan con la tabla de la derecha.
  459. </para>
  460. <para>
  461. Algunos RDBMS no soportan este tipo de join, pero en general, cualquier unión
  462. por la derecha puede representarse por una unión por la izquierda invirtiendo
  463. el orden de las tablas.
  464. </para>
  465. </listitem>
  466. <listitem>
  467. <para>
  468. <command>FULL JOIN</command> con el método
  469. <code>joinFull(table, condition, [columns])</code>.
  470. </para>
  471. <para>
  472. Una unión externa total es como una combinación de una unión exterior por
  473. la izquierda y una unión exterior por la derecha.
  474. Todas las filas de ambas tablas son incluidas, vinculadas entre sí
  475. en la misma fila si satisfacen la condición de unión, y en otro
  476. caso, se vinculan con valores nulos en lugar de columnas de la otra tabla.
  477. </para>
  478. <para>
  479. Algunos RDBMS no soportan este tipo de unión.
  480. </para>
  481. </listitem>
  482. <listitem>
  483. <para>
  484. <command>CROSS JOIN</command> con el método
  485. <code>joinCross(table, [columns])</code>.
  486. </para>
  487. <para>
  488. Una unión cruzada es un Producto Cartesiano. Cada fila en la primera tabla
  489. es pareada con cada una en la segunda tabla.
  490. Por lo tanto, el número de filas en el resultado es igual al producto del
  491. número de filas en cada tabla.
  492. Puede filtrar el conjunto de resultados con el uso de condiciones en un
  493. cláusula WHERE; de esta forma una unión cruzada es similar a la antigua
  494. sintaxis de unión en SQL-89.
  495. </para>
  496. <para>
  497. El método <code>joinCross()</code> no tiene parámetros para especificar una
  498. condición de unión. Algunos RDBMS no soportan este tipo de unión.
  499. </para>
  500. </listitem>
  501. <listitem>
  502. <para>
  503. <command>NATURAL JOIN</command> con el método
  504. <code>joinNatural(table, [columns])</code>.
  505. </para>
  506. <para>
  507. Una unión natural compara cualquier columa(s) que aparezca con el nombre
  508. en ambas tablas. La comparación es el equivalente de todas las columna(s);
  509. comparando las columnas usando desigualdad no es una unión natural.
  510. Solo la unión interna natural es soportada por este API, aun cuando SQL
  511. permita una unión externa natural.
  512. </para>
  513. <para>
  514. El método <code>joinNatural()</code> no tiene parámetros para especificar una condición.
  515. </para>
  516. </listitem>
  517. </itemizedlist>
  518. <para>
  519. Además de los métodos de unión, puede simplificar las consultas
  520. usando métodos JoinUsing. En vez de proveer una condición completa a la unión,
  521. simplemente pase el nombre de columna en la que se hará la unión y
  522. el objeto <classname>Zend_Db_Select</classname> completa la condición.
  523. </para>
  524. <example id="zend.db.select.building.joinusing.example">
  525. <title>Ejemplo de método joinUsing()</title>
  526. <programlisting role="php"><![CDATA[
  527. // Construya esta consulta:
  528. // SELECT *
  529. // FROM "table1"
  530. // JOIN "table2"
  531. // ON "table1".column1 = "table2".column1
  532. // WHERE column2 = 'foo'
  533. $select = $db->select()
  534. ->from('table1')
  535. ->joinUsing('table2', 'column1')
  536. ->where('column2 = ?', 'foo');
  537. ]]></programlisting>
  538. </example>
  539. <para>
  540. Cada uno de los métodos aplicables para uniones en el componente
  541. <classname>Zend_Db_Select</classname> tiene su correspondiente método 'using' (usando)
  542. </para>
  543. <itemizedlist>
  544. <listitem>
  545. <para>
  546. <code>joinUsing(table, join, [columns])</code> y
  547. <code>joinInnerUsing(table, join, [columns])</code>
  548. </para>
  549. </listitem>
  550. <listitem>
  551. <para>
  552. <code>joinLeftUsing(table, join, [columns])</code>
  553. </para>
  554. </listitem>
  555. <listitem>
  556. <para>
  557. <code>joinRightUsing(table, join, [columns])</code>
  558. </para>
  559. </listitem>
  560. <listitem>
  561. <para>
  562. <code>joinFullUsing(table, join, [columns])</code>
  563. </para>
  564. </listitem>
  565. </itemizedlist>
  566. </sect3>
  567. <sect3 id="zend.db.select.building.where">
  568. <title>Agregar una cláusula WHERE</title>
  569. <para>
  570. Puede especificar un criterio para restringir las filas de resultado
  571. usando el método <code>where()</code>. El primer argumento de este método
  572. es una expresión SQL, y esta expresión es usada como una expresión SQL
  573. <code>WHERE</code> en la consulta.
  574. </para>
  575. <example id="zend.db.select.building.where.example">
  576. <title>Ejemplo del método where()</title>
  577. <programlisting role="php"><![CDATA[
  578. // Construya esta consulta:
  579. // SELECT product_id, product_name, price
  580. // FROM "products"
  581. // WHERE price > 100.00
  582. $select = $db->select()
  583. ->from('products',
  584. array('product_id', 'product_name', 'price'))
  585. ->where('price > 100.00');
  586. ]]></programlisting>
  587. </example>
  588. <note>
  589. <para>
  590. No se aplica entrecomillado en una expresión dada en el método <code>where()</code> u
  591. <code>orWhere()</code>. Si tiene nombres de columnas que necesitan ser entrecomillados,
  592. debe usar el método <code>quoteIdentifier()</code> para formar el string de la condición.
  593. </para>
  594. </note>
  595. <para>
  596. El segundo argumento del método <code>where()</code> es opcional.
  597. Es un valor para sustituir en la expresión. <classname>Zend_Db_Select</classname> entrecomilla el valor
  598. y lo sustituye por un signo de interrogación ("<code>?</code>") en la expresión.
  599. </para>
  600. <para>
  601. Este método acepta solo un parámetro. Si tiene una expresión
  602. en la cual necesita sustituir múltiples variables, deberá formar
  603. el string manualmente, interpolando variables y realizando entrecomillado
  604. manualmente.
  605. </para>
  606. <example id="zend.db.select.building.where.example-param">
  607. <title>Ejemplo de parámetro en el método where()</title>
  608. <programlisting role="php"><![CDATA[
  609. // Construya esta consulta:
  610. // SELECT product_id, product_name, price
  611. // FROM "products"
  612. // WHERE (price > 100.00)
  613. $minimumPrice = 100;
  614. $select = $db->select()
  615. ->from('products',
  616. array('product_id', 'product_name', 'price'))
  617. ->where('price > ?', $minimumPrice);
  618. ]]></programlisting>
  619. </example>
  620. <para>
  621. Puede invocar el método <code>where()</code> múltiples veces en el mismo objeto
  622. <classname>Zend_Db_Select</classname>. La consulta resultante combina los términos multiples
  623. usando <code>AND</code> entre ellos.
  624. </para>
  625. <example id="zend.db.select.building.where.example-and">
  626. <title>Ejemplo de métodos where() múltiples</title>
  627. <programlisting role="php"><![CDATA[
  628. // Construya esta consulta:
  629. // SELECT product_id, product_name, price
  630. // FROM "products"
  631. // WHERE (price > 100.00)
  632. // AND (price < 500.00)
  633. $minimumPrice = 100;
  634. $maximumPrice = 500;
  635. $select = $db->select()
  636. ->from('products',
  637. array('product_id', 'product_name', 'price'))
  638. ->where('price > ?', $minimumPrice)
  639. ->where('price < ?', $maximumPrice);
  640. ]]></programlisting>
  641. </example>
  642. <para>
  643. Si necesita combinar terminos usando<code>OR</code>, use el método
  644. <code>orWhere()</code>. Este método se usa del mismo modo que el método
  645. <code>where()</code>, excepto que el término especificado es precedido por
  646. <code>OR</code>, en lugar de <code>AND</code>.
  647. </para>
  648. <example id="zend.db.select.building.where.example-or">
  649. <title>Ejemplo del método orWhere()</title>
  650. <programlisting role="php"><![CDATA[
  651. // Construya esta consulta:
  652. // SELECT product_id, product_name, price
  653. // FROM "products"
  654. // WHERE (price < 100.00)
  655. // OR (price > 500.00)
  656. $minimumPrice = 100;
  657. $maximumPrice = 500;
  658. $select = $db->select()
  659. ->from('products',
  660. array('product_id', 'product_name', 'price'))
  661. ->where('price < ?', $minimumPrice)
  662. ->orWhere('price > ?', $maximumPrice);
  663. ]]></programlisting>
  664. </example>
  665. <para>
  666. <classname>Zend_Db_Select</classname> automáticamente pone paréntesis alrededor de cada expresión
  667. que especifique usando el método <code>where()</code> u <code>orWhere()</code>.
  668. Esto ayuda a asegurar que la precedencia del operador Booleano no cause resultados
  669. inesperados.
  670. </para>
  671. <example id="zend.db.select.building.where.example-parens">
  672. <title>Ejemplos de Expresiones Booleanas con paréntesis</title>
  673. <programlisting role="php"><![CDATA[
  674. // Construya esta consulta:
  675. // SELECT product_id, product_name, price
  676. // FROM "products"
  677. // WHERE (price < 100.00 OR price > 500.00)
  678. // AND (product_name = 'Apple')
  679. $minimumPrice = 100;
  680. $maximumPrice = 500;
  681. $prod = 'Apple';
  682. $select = $db->select()
  683. ->from('products',
  684. array('product_id', 'product_name', 'price'))
  685. ->where("price < $minimumPrice OR price > $maximumPrice")
  686. ->where('product_name = ?', $prod);
  687. ]]></programlisting>
  688. </example>
  689. <para>
  690. En el ejemplo anterior, los resultados deberían ser diferentes sin paréntesis,
  691. porque <code>AND</code> tiene precedencia más alta respecto a <code>OR</code>.
  692. <classname>Zend_Db_Select</classname> aplica el parentesis con un efecto tal que la expresión en sucesivas
  693. llamadas al método <code>where()</code> vincula de forma más fuerte el <code>AND</code>
  694. que combina las expresiones.
  695. </para>
  696. </sect3>
  697. <sect3 id="zend.db.select.building.group">
  698. <title>Agregando una cláusula GROUP BY</title>
  699. <para>
  700. En SQL, la cláusula <code>GROUP BY</code> permite reducir el número
  701. de filas del resultado de una consulta a una fila por cada valor único
  702. encontrado en la(s) columna(s) nombrada(s) en la cláusula
  703. <code>GROUP BY</code>.
  704. </para>
  705. <para>
  706. En <classname>Zend_Db_Select</classname>, puede especificar la(s) columna(s) que usar para el
  707. cálculo de grupos de filas usando el método <code>group()</code>.
  708. El argumento de este método es una columna o un array de columnas
  709. que se usarán en la cláusula <code>GROUP BY</code>.
  710. </para>
  711. <example id="zend.db.select.building.group.example">
  712. <title>Ejemplo del método group()</title>
  713. <programlisting role="php"><![CDATA[
  714. // Construya esta consulta:
  715. // SELECT p."product_id", COUNT(*) AS line_items_per_product
  716. // FROM "products" AS p JOIN "line_items" AS l
  717. // ON p.product_id = l.product_id
  718. // GROUP BY p.product_id
  719. $select = $db->select()
  720. ->from(array('p' => 'products'),
  721. array('product_id'))
  722. ->join(array('l' => 'line_items'),
  723. 'p.product_id = l.product_id',
  724. array('line_items_per_product' => 'COUNT(*)'))
  725. ->group('p.product_id');
  726. ]]></programlisting>
  727. </example>
  728. <para>
  729. Como el array de columnas del método <code>from()</code>, se puede usar
  730. correlación de nombres en el string de nombre de columna, y la columna será
  731. entrecomillada como un identificador, salvo que el string contenga paréntesis
  732. o sea un objeto de tipo <classname>Zend_Db_Expr</classname>.
  733. </para>
  734. </sect3>
  735. <sect3 id="zend.db.select.building.having">
  736. <title>Agregando una cláusula HAVING</title>
  737. <para>
  738. En SQL, la cláusula <code>HAVING</code> aplica una condición de restricción
  739. en grupos de filas. Es similar a una cláusula <code>WHERE</code>
  740. aplicando una condición de restricción a las filas. Pero las 2 cláusulas
  741. son diferentes porque las condiciones <code>WHERE</code>
  742. son aplicadas antes que definan los grupos, mientras que las condiciones
  743. <code>HAVING</code> son aplicadas después que los grupos son definidos.
  744. </para>
  745. <para>
  746. En <classname>Zend_Db_Select</classname>, puede especificar condiciones para restringir
  747. grupos usando el método <code>having()</code>. Su uso es similar al
  748. del método <code>where()</code>. El primer agumento es un string
  749. conteniendo una expresión SQL. El segundo argumento es un valor
  750. que es usado para reemplazar un parámetro marcador de posición en la
  751. expresión SQL. Las expresiones dadas en multiples invocaciones al método
  752. <code>having()</code> son combinadas usando el operador Booleano
  753. <code>AND</code>, o el operador <code>OR</code> si usa el método
  754. <code>orHaving()</code>.
  755. </para>
  756. <example id="zend.db.select.building.having.example">
  757. <title>Ejemplo del método having()</title>
  758. <programlisting role="php"><![CDATA[
  759. // Construya esta consulta:
  760. // SELECT p."product_id", COUNT(*) AS line_items_per_product
  761. // FROM "products" AS p JOIN "line_items" AS l
  762. // ON p.product_id = l.product_id
  763. // GROUP BY p.product_id
  764. // HAVING line_items_per_product > 10
  765. $select = $db->select()
  766. ->from(array('p' => 'products'),
  767. array('product_id'))
  768. ->join(array('l' => 'line_items'),
  769. 'p.product_id = l.product_id',
  770. array('line_items_per_product' => 'COUNT(*)'))
  771. ->group('p.product_id')
  772. ->having('line_items_per_product > 10');
  773. ]]></programlisting>
  774. </example>
  775. <note>
  776. <para>
  777. No se aplica entrecomillado a expresiones dadas al método <code>having()</code> u
  778. <code>orHaving()</code>. Si tiene nombres de columnas que deban ser
  779. entrecomillados, deberá usar <code>quoteIdentifier()</code> para
  780. formar el string de la condición.
  781. </para>
  782. </note>
  783. </sect3>
  784. <sect3 id="zend.db.select.building.order">
  785. <title>Agregar una cláusula ORDER BY</title>
  786. <para>
  787. En SQL, la cláusula <code>ORDER BY</code> especifica una o más
  788. columnas o expresiones por el cual el resultado de la consulta
  789. será ordenado. Si multiples columnas son listadas, las columnas secundarias
  790. serán usadas para resolver relaciones; el orden de clasificación es determinado
  791. por columnas secundarias si la columna anterior contiene valores idénticos.
  792. El orden por defecto es del menor valor al mayor valor. Puede también
  793. ordenar de mayor a menor valor para una columna dada en la lista espeificando
  794. la palabra clave <code>DESC</code> después de la columna.
  795. </para>
  796. <para>
  797. En <classname>Zend_Db_Select</classname>, puede usar el método <code>order()</code>
  798. para especificar una columna o un array de columnas por el cual ordenar.
  799. Cada elemento del array es un string nombrando la columna. Opcionalmente con la
  800. palabra reservada <code>ASC</code> o <code>DESC</code> siguiendola, separada
  801. por un espacio.
  802. </para>
  803. <para>
  804. Como en el método <code>from()</code> y <code>group()</code>, los nombres de columnas
  805. son entrecomillados como identificadores, a menos que contengan paréntesis
  806. o sean un obheto de tipo <classname>Zend_Db_Expr</classname>.
  807. </para>
  808. <example id="zend.db.select.building.order.example">
  809. <title>Ejemplo del método order()</title>
  810. <programlisting role="php"><![CDATA[
  811. // Construya esta consulta:
  812. // SELECT p."product_id", COUNT(*) AS line_items_per_product
  813. // FROM "products" AS p JOIN "line_items" AS l
  814. // ON p.product_id = l.product_id
  815. // GROUP BY p.product_id
  816. // ORDER BY "line_items_per_product" DESC, "product_id"
  817. $select = $db->select()
  818. ->from(array('p' => 'products'),
  819. array('product_id'))
  820. ->join(array('l' => 'line_items'),
  821. 'p.product_id = l.product_id',
  822. array('line_items_per_product' => 'COUNT(*)'))
  823. ->group('p.product_id')
  824. ->order(array('line_items_per_product DESC',
  825. 'product_id'));
  826. ]]></programlisting>
  827. </example>
  828. </sect3>
  829. <sect3 id="zend.db.select.building.limit">
  830. <title>Agregando una cláusula LIMIT</title>
  831. <para>
  832. Algunos RDBMS extienden una consulta SQL con una cláusula conocida como <code>LIMIT</code>.
  833. Esta cláusuala reduce el número de filas en el resultado a no más de un número
  834. especificado. También puede especificar saltar el número de filas antes
  835. de empezar la salida. Esta característica hace más fácil tomar un subconjunto de
  836. resultados, por ejemplo cuando mostramos los resultados de una consulta en
  837. páginas progresivas de salida.
  838. </para>
  839. <para>
  840. En <classname>Zend_Db_Select</classname>, puede usar el método <code>limit()</code> para especificar
  841. la cantidad de filas y el número de filas que saltar. El primer argumento es
  842. el método es el número de filas deseado. El segundo argument es el número de filas que saltar.
  843. </para>
  844. <example id="zend.db.select.building.limit.example">
  845. <title>Ejemplo del método limit()</title>
  846. <programlisting role="php"><![CDATA[
  847. // Construya esta consulta:
  848. // SELECT p."product_id", p."product_name"
  849. // FROM "products" AS p
  850. // LIMIT 10, 20
  851. $select = $db->select()
  852. ->from(array('p' => 'products'),
  853. array('product_id', 'product_name'))
  854. ->limit(10, 20);
  855. ]]></programlisting>
  856. </example>
  857. <note>
  858. <para>
  859. La sintaxis de <code>LIMIT</code> no está soportada por todos los RDBMS brands.
  860. Algunos RDBMS requieren diferente sintaxis para soportar una funcionalidad similar
  861. Cada clase <classname>Zend_Db_Adapter_Abstract</classname> incluye un método
  862. para producir el SQL apropiado para cada RDBMS.
  863. </para>
  864. </note>
  865. <para>
  866. Use el método <code>limitPage()</code> como un modo alternativo de
  867. especificar la cantidad de filas y el offset.
  868. Este método permite limitar el conjunto resultado a una serie de subconjuntos
  869. de tamaño fijo de filas del total del resultado de la consulta.
  870. En otras palabras, puede especificar el tamaño de una "página" de resultados,
  871. y el número ordinal de la página simple donde se espera que devuelva la consulta.
  872. El número de página es el primer argumento del método <code>limitPage()</code>,
  873. y la longitud de la página es el segundo argumento.
  874. Ambos son argumentos requeridos; no tienen valores por omisión.
  875. </para>
  876. <example id="zend.db.select.building.limit.example2">
  877. <title>Ejemplo del método limitPage()</title>
  878. <programlisting role="php"><![CDATA[
  879. // Construya esta consulta:
  880. // SELECT p."product_id", p."product_name"
  881. // FROM "products" AS p
  882. // LIMIT 10, 20
  883. $select = $db->select()
  884. ->from(array('p' => 'products'),
  885. array('product_id', 'product_name'))
  886. ->limitPage(2, 10);
  887. ]]></programlisting>
  888. </example>
  889. </sect3>
  890. <sect3 id="zend.db.select.building.distinct">
  891. <title>Agregar el modificador DISTINCT a la consulta</title>
  892. <para>
  893. El método <code>distinct()</code> permite agregar la palabra
  894. clave a la consulta <code>DISTINCT</code> a su consulta SQL.
  895. </para>
  896. <example id="zend.db.select.building.distinct.example">
  897. <title>Ejemplo del método distinct()</title>
  898. <programlisting role="php"><![CDATA[
  899. // Construya esta consulta:
  900. // SELECT DISTINCT p."product_name"
  901. // FROM "products" AS p
  902. $select = $db->select()
  903. ->distinct()
  904. ->from(array('p' => 'products'), 'product_name');
  905. ]]></programlisting>
  906. </example>
  907. </sect3>
  908. <sect3 id="zend.db.select.building.for-update">
  909. <title>Agregar el modificador FOR UPDATE</title>
  910. <para>
  911. El método <code>forUpdate()</code> permite agregar el modificador
  912. <code>FOR UPDATE</code> a su consulta SQL.
  913. </para>
  914. <example id="zend.db.select.building.for-update.example">
  915. <title>Example of forUpdate() method</title>
  916. <programlisting role="php"><![CDATA[
  917. // Construya esta consulta:
  918. // SELECT FOR UPDATE p.*
  919. // FROM "products" AS p
  920. $select = $db->select()
  921. ->forUpdate()
  922. ->from(array('p' => 'products'));
  923. ]]></programlisting>
  924. </example>
  925. </sect3>
  926. </sect2>
  927. <sect2 id="zend.db.select.execute">
  928. <title>Ejecutando consultas Select</title>
  929. <para>
  930. En esta sección se describe cómo ejecutar una consulta representada por
  931. un objeto <classname>Zend_Db_Select</classname>.
  932. </para>
  933. <sect3 id="zend.db.select.execute.query-adapter">
  934. <title>Ejecutando Consultas SelectExecuting desde el Adaptador de Base de Datos</title>
  935. <para>
  936. Puede ejecutar la consulta representada por el objeto <classname>Zend_Db_Select</classname> pasándolo
  937. como primer argumento al método <code>query()</code> de un objeto <classname>Zend_Db_Adapter_Abstract</classname>.
  938. Use objetos <classname>Zend_Db_Select</classname> en lugar de un string de consulta.
  939. </para>
  940. <para>
  941. El método <code>query()</code> devuelve un objeto de tipo
  942. Zend_Db_Statement o PDOStatement, dependiendo del tipo de adaptador.
  943. </para>
  944. <example id="zend.db.select.execute.query-adapter.example">
  945. <title>Ejemplo usando el método adaptador query() del Adaptador de Base de datos</title>
  946. <programlisting role="php"><![CDATA[
  947. $select = $db->select()
  948. ->from('products');
  949. $stmt = $db->query($select);
  950. $result = $stmt->fetchAll();
  951. ]]></programlisting>
  952. </example>
  953. </sect3>
  954. <sect3 id="zend.db.select.execute.query-select">
  955. <title>Ejecutando Consultas Select desde el Objeto</title>
  956. <para>
  957. Como alternativa al uso del método <code>query()</code> del objeto adaptador,
  958. puede usar el método <code>query()</code> del objeto <classname>Zend_Db_Select</classname>. Ambos
  959. métodos devuelven un objeto de tipo Zend_Db_Statement o PDOStatement, dependiendo
  960. del tipo de adaptador.
  961. </para>
  962. <example id="zend.db.select.execute.query-select.example">
  963. <title>Ejempo usando el método query() del objeto Select</title>
  964. <programlisting role="php"><![CDATA[
  965. $select = $db->select()
  966. ->from('products');
  967. $stmt = $select->query();
  968. $result = $stmt->fetchAll();
  969. ]]></programlisting>
  970. </example>
  971. </sect3>
  972. <sect3 id="zend.db.select.execute.tostring">
  973. <title>Convertiendo un Objeto Select a un String SQL</title>
  974. <para>
  975. Si necesita acceder a una represantación en un string de la
  976. consulta SQL correspondiente al objeto <classname>Zend_Db_Select</classname>,
  977. use el método <code>__toString()</code>.
  978. </para>
  979. <example id="zend.db.select.execute.tostring.example">
  980. <title>Ejemplo del método __toString()</title>
  981. <programlisting role="php"><![CDATA[
  982. $select = $db->select()
  983. ->from('products');
  984. $sql = $select->__toString();
  985. echo "$sql\n";
  986. // La salida es el string:
  987. // SELECT * FROM "products"
  988. ]]></programlisting>
  989. </example>
  990. </sect3>
  991. </sect2>
  992. <sect2 id="zend.db.select.other">
  993. <title>Otros Métodos</title>
  994. <para>
  995. Esta sección describe otros métodos de <classname>Zend_Db_Select</classname> que no han
  996. sido cubiertos antes: <code>getPart()</code> y <code>reset()</code>.
  997. </para>
  998. <sect3 id="zend.db.select.other.get-part">
  999. <title>Obtener Partes de un Objeto Select</title>
  1000. <para>
  1001. El método <code>getPart()</code> devuelve una representación de
  1002. una parte de su consulta SQL. Por ejemplo, puede usar este
  1003. método para devolver un array de expresiones para la cláusula
  1004. <code>WHERE</code>, o el array de columnas (o expresiones de
  1005. columnas) que estan en la lista del <code>SELECT</code>, o los
  1006. valores de la cantidad y comienzo para la cláusula
  1007. <code>LIMIT</code>.
  1008. </para>
  1009. <para>
  1010. El valor de retorno no es un string conteniendo un fragmento
  1011. de la sintaxis SQL. El valor de retorno es una representación,
  1012. típicamente un array con una estructura que contiene valores y
  1013. expresiones. Cada parte de la consulta tiene una estructura
  1014. diferente.
  1015. </para>
  1016. <para>
  1017. El único argumento del método <code>getPart()</code> es un
  1018. string que identifica qué parte del la consulta Select va a
  1019. devolver. Por ejemplo, el string <code>'from'</code> identifica
  1020. la parte del objeto Select que almacena la información de las
  1021. tablas de la cláusula <code>FROM</code>, incluyendo uniones de
  1022. tablas.
  1023. </para>
  1024. <para>
  1025. La clase <classname>Zend_Db_Select</classname> define constantes que puedes usar para
  1026. las partes de la consulta SQL.
  1027. Puede usar estas definiciones de constantes, o los strings
  1028. literales.
  1029. </para>
  1030. <table id="zend.db.select.other.get-part.table">
  1031. <title>Constantes usedas por getPart() y reset()</title>
  1032. <tgroup cols="2">
  1033. <thead>
  1034. <row>
  1035. <entry>Constante</entry>
  1036. <entry>Valor del String</entry>
  1037. </row>
  1038. </thead>
  1039. <tbody>
  1040. <row>
  1041. <entry><classname>Zend_Db_Select::DISTINCT</classname></entry>
  1042. <entry><classname>'distinct'</classname></entry>
  1043. </row>
  1044. <row>
  1045. <entry><classname>Zend_Db_Select::FOR_UPDATE</classname></entry>
  1046. <entry><classname>'forupdate'</classname></entry>
  1047. </row>
  1048. <row>
  1049. <entry><classname>Zend_Db_Select::COLUMNS</classname></entry>
  1050. <entry><classname>'columns'</classname></entry>
  1051. </row>
  1052. <row>
  1053. <entry><classname>Zend_Db_Select::FROM</classname></entry>
  1054. <entry><classname>'from'</classname></entry>
  1055. </row>
  1056. <row>
  1057. <entry><classname>Zend_Db_Select::WHERE</classname></entry>
  1058. <entry><classname>'where'</classname></entry>
  1059. </row>
  1060. <row>
  1061. <entry><classname>Zend_Db_Select::GROUP</classname></entry>
  1062. <entry><classname>'group'</classname></entry>
  1063. </row>
  1064. <row>
  1065. <entry><classname>Zend_Db_Select::HAVING</classname></entry>
  1066. <entry><classname>'having'</classname></entry>
  1067. </row>
  1068. <row>
  1069. <entry><classname>Zend_Db_Select::ORDER</classname></entry>
  1070. <entry><classname>'order'</classname></entry>
  1071. </row>
  1072. <row>
  1073. <entry><classname>Zend_Db_Select::LIMIT_COUNT</classname></entry>
  1074. <entry><classname>'limitcount'</classname></entry>
  1075. </row>
  1076. <row>
  1077. <entry><classname>Zend_Db_Select::LIMIT_OFFSET</classname></entry>
  1078. <entry><classname>'limitoffset'</classname></entry>
  1079. </row>
  1080. </tbody>
  1081. </tgroup>
  1082. </table>
  1083. <example id="zend.db.select.other.get-part.example">
  1084. <title>Ejemplo del método getPart()</title>
  1085. <programlisting role="php"><![CDATA[
  1086. $select = $db->select()
  1087. ->from('products')
  1088. ->order('product_id');
  1089. // Puede especificar un string literal para especificar la parte
  1090. $orderData = $select->getPart( 'order' );
  1091. // Puede usar una constante para especificar la misma parte
  1092. $orderData = $select->getPart( Zend_Db_Select::ORDER );
  1093. // El valor de retorno puede ser una estructura en un array, no un string.
  1094. // Cada parte tiene distinta estructura.
  1095. print_r( $orderData );
  1096. ]]></programlisting>
  1097. </example>
  1098. </sect3>
  1099. <sect3 id="zend.db.select.other.reset">
  1100. <title>Restableciendo Partes de un Objeto</title>
  1101. <para>
  1102. El método <code>reset()</code> permite limpiar una parte
  1103. específica de la consulta SQL, o limpia todas las partes de la
  1104. consulta SQL si omite el argumento.
  1105. </para>
  1106. <para>
  1107. El argumento es opcional. Puede especificar la parte de la
  1108. consulta que será limpiada, usando los mismos strings que usa el
  1109. argumento del método <code>getPart()</code>. La parte de la
  1110. consulta que especifique se reestablecerá a su estado por
  1111. omisión.
  1112. </para>
  1113. <para>
  1114. Si omite el parámetro, <code>reset()</code> cambia todas las
  1115. partes de la consulta a su estado por omisión. Esto hace que
  1116. el objeto Zend_Db_Select sea equivalente a crear un nuevo
  1117. objeto, como si acabase de instanciarlo.
  1118. </para>
  1119. <example id="zend.db.select.other.reset.example">
  1120. <title>Ejemplo del método reset()</title>
  1121. <programlisting role="php"><![CDATA[
  1122. // Construya esta consulta:
  1123. // SELECT p.*
  1124. // FROM "products" AS p
  1125. // ORDER BY "product_name"
  1126. $select = $db->select()
  1127. ->from(array('p' => 'products')
  1128. ->order('product_name');
  1129. // Requisito cambiado, en su lugar un orden diferente de columnas:
  1130. // SELECT p.*
  1131. // FROM "products" AS p
  1132. // ORDER BY "product_id"
  1133. // Limpia una parte para poder redefinirla
  1134. $select->reset( Zend_Db_Select::ORDER );
  1135. // Y especificar una columna diferente
  1136. $select->order('product_id');
  1137. // Limpia todas las partes de la consulta
  1138. $select->reset();
  1139. ]]></programlisting>
  1140. </example>
  1141. </sect3>
  1142. </sect2>
  1143. </sect1>
  1144. <!--
  1145. vim:se ts=4 sw=4 et:
  1146. -->