Zend_Db_Select.xml 57 KB

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