1572 lines
437 KiB
HTML
1572 lines
437 KiB
HTML
|
|
||
|
<div id="content">
|
||
|
<h1 align="center">Source for file Query.php</h1>
|
||
|
<p>Documentation is available at <a href="../Doctrine/_Doctrine---Query.php.html">Query.php</a></p>
|
||
|
<div class="src-code"><span class="php">
|
||
|
<ol><li><div class="src-line"><a name="a1"></a><span class="src-php"><?php</span></div></li>
|
||
|
<li><div class="src-line"><a name="a2"></a><span class="src-comm">/*</span></div></li>
|
||
|
<li><div class="src-line"><a name="a3"></a><span class="src-comm"> * $Id: Query.php 2287 2007-08-29 21:36:36Z zYne $</span></div></li>
|
||
|
<li><div class="src-line"><a name="a4"></a><span class="src-comm"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a5"></a><span class="src-comm"> * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS</span></div></li>
|
||
|
<li><div class="src-line"><a name="a6"></a><span class="src-comm"> * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT</span></div></li>
|
||
|
<li><div class="src-line"><a name="a7"></a><span class="src-comm"> * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR</span></div></li>
|
||
|
<li><div class="src-line"><a name="a8"></a><span class="src-comm"> * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT</span></div></li>
|
||
|
<li><div class="src-line"><a name="a9"></a><span class="src-comm"> * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,</span></div></li>
|
||
|
<li><div class="src-line"><a name="a10"></a><span class="src-comm"> * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT</span></div></li>
|
||
|
<li><div class="src-line"><a name="a11"></a><span class="src-comm"> * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,</span></div></li>
|
||
|
<li><div class="src-line"><a name="a12"></a><span class="src-comm"> * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY</span></div></li>
|
||
|
<li><div class="src-line"><a name="a13"></a><span class="src-comm"> * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT</span></div></li>
|
||
|
<li><div class="src-line"><a name="a14"></a><span class="src-comm"> * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE</span></div></li>
|
||
|
<li><div class="src-line"><a name="a15"></a><span class="src-comm"> * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.</span></div></li>
|
||
|
<li><div class="src-line"><a name="a16"></a><span class="src-comm"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a17"></a><span class="src-comm"> * This software consists of voluntary contributions made by many individuals</span></div></li>
|
||
|
<li><div class="src-line"><a name="a18"></a><span class="src-comm"> * and is licensed under the LGPL. For more information, see</span></div></li>
|
||
|
<li><div class="src-line"><a name="a19"></a><span class="src-comm"> * <http://www.phpdoctrine.com>.</span></div></li>
|
||
|
<li><div class="src-line"><a name="a20"></a><span class="src-comm"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a21"></a><span class="src-id"><a href="../Doctrine/Doctrine.html">Doctrine</a></span><span class="src-sym">::</span><a href="../Doctrine/Doctrine.html#methodautoload">autoload</a><span class="src-sym">(</span><span class="src-str">'Doctrine_Query_Abstract'</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a22"></a><span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a23"></a><span class="src-doc"> * Doctrine_Query</span></div></li>
|
||
|
<li><div class="src-line"><a name="a24"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a25"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@package</span><span class="src-doc"> Doctrine</span></div></li>
|
||
|
<li><div class="src-line"><a name="a26"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@license</span><span class="src-doc"> http://www.opensource.org/licenses/lgpl-license.php LGPL</span></div></li>
|
||
|
<li><div class="src-line"><a name="a27"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@category</span><span class="src-doc"> Object Relational Mapping</span></div></li>
|
||
|
<li><div class="src-line"><a name="a28"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@link</span><span class="src-doc"> www.phpdoctrine.com</span></div></li>
|
||
|
<li><div class="src-line"><a name="a29"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@since</span><span class="src-doc"> 1.0</span></div></li>
|
||
|
<li><div class="src-line"><a name="a30"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@version</span><span class="src-doc"> $Revision: 2287 $</span></div></li>
|
||
|
<li><div class="src-line"><a name="a31"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@author</span><span class="src-doc"> Konsta Vesterinen <kvesteri@cc.hut.fi></span></div></li>
|
||
|
<li><div class="src-line"><a name="a32"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a33"></a><span class="src-key">class </span><a href="../Doctrine/Doctrine_Query.html">Doctrine_Query</a> <span class="src-key">extends </span><a href="../Doctrine/Doctrine_Query_Abstract.html">Doctrine_Query_Abstract</a> <span class="src-key">implements </span><span class="src-id">Countable</span></div></li>
|
||
|
<li><div class="src-line"><a name="a34"></a><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a35"></a> <span class="src-key">const </span><a href="../Doctrine/Doctrine_Query.html#constSTATE_CLEAN">STATE_CLEAN</a> = <span class="src-num">1</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a36"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a37"></a> <span class="src-key">const </span><a href="../Doctrine/Doctrine_Query.html#constSTATE_DIRTY">STATE_DIRTY</a> = <span class="src-num">2</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a38"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a39"></a> <span class="src-key">const </span><a href="../Doctrine/Doctrine_Query.html#constSTATE_DIRECT">STATE_DIRECT</a> = <span class="src-num">3</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a40"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a41"></a> <span class="src-key">const </span><a href="../Doctrine/Doctrine_Query.html#constSTATE_LOCKED">STATE_LOCKED</a> = <span class="src-num">4</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a42"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a43"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a44"></a> <span class="src-key">protected </span><a href="../Doctrine/Doctrine_Query.html#var$subqueryAliases">$subqueryAliases</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a45"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a46"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">boolean </span><span class="src-doc-var">$needsSubquery </span></div></li>
|
||
|
<li><div class="src-line"><a name="a47"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a48"></a> <span class="src-key">protected </span><a href="../Doctrine/Doctrine_Query.html#var$needsSubquery">$needsSubquery</a> = <span class="src-id">false</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a49"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a50"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">boolean </span><span class="src-doc-var">$isSubquery </span><span class="src-doc"> whether or not this query object is a subquery of another</span></div></li>
|
||
|
<li><div class="src-line"><a name="a51"></a><span class="src-doc"> * query object</span></div></li>
|
||
|
<li><div class="src-line"><a name="a52"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a53"></a> <span class="src-key">protected </span><a href="../Doctrine/Doctrine_Query.html#var$isSubquery">$isSubquery</a><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a54"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a55"></a> <span class="src-key">protected </span><a href="../Doctrine/Doctrine_Query.html#var$isLimitSubqueryUsed">$isLimitSubqueryUsed</a> = <span class="src-id">false</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a56"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a57"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@var </span><span class="src-doc-type">array </span><span class="src-doc-var">$_neededTableAliases </span><span class="src-doc"> an array containing the needed table aliases</span></div></li>
|
||
|
<li><div class="src-line"><a name="a58"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a59"></a> <span class="src-key">protected </span><a href="../Doctrine/Doctrine_Query.html#var$_neededTables">$_neededTables</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a60"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a61"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@var </span><span class="src-doc-type">array </span><span class="src-doc-var">$pendingFields </span></div></li>
|
||
|
<li><div class="src-line"><a name="a62"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a63"></a> <span class="src-key">protected </span><a href="../Doctrine/Doctrine_Query.html#var$pendingFields">$pendingFields</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a64"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a65"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@var </span><span class="src-doc-type">array </span><span class="src-doc-var">$pendingSubqueries </span><span class="src-doc"> SELECT part subqueries, these are called pending subqueries since</span></div></li>
|
||
|
<li><div class="src-line"><a name="a66"></a><span class="src-doc"> * they cannot be parsed directly (some queries might be correlated)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a67"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a68"></a> <span class="src-key">protected </span><a href="../Doctrine/Doctrine_Query.html#var$pendingSubqueries">$pendingSubqueries</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a69"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a70"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@var </span><span class="src-doc-type">array </span><span class="src-doc-var">$_parsers </span><span class="src-doc"> an array of parser objects, each DQL query part has its own parser</span></div></li>
|
||
|
<li><div class="src-line"><a name="a71"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a72"></a> <span class="src-key">protected </span><a href="../Doctrine/Doctrine_Query.html#var$_parsers">$_parsers</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a73"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a74"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@var </span><span class="src-doc-type">array </span><span class="src-doc-var">$_enumParams </span><span class="src-doc"> an array containing the keys of the parameters that should be enumerated</span></div></li>
|
||
|
<li><div class="src-line"><a name="a75"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a76"></a> <span class="src-key">protected </span><a href="../Doctrine/Doctrine_Query.html#var$_enumParams">$_enumParams</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a77"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a78"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a79"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@var </span><span class="src-doc-type">array </span><span class="src-doc-var">$_dqlParts </span><span class="src-doc"> an array containing all DQL query parts</span></div></li>
|
||
|
<li><div class="src-line"><a name="a80"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a81"></a> <span class="src-key">protected </span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">$_dqlParts</a> = <span class="src-key">array</span><span class="src-sym">(</span></div></li>
|
||
|
<li><div class="src-line"><a name="a82"></a> <span class="src-str">'select' </span>=> <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">,</span></div></li>
|
||
|
<li><div class="src-line"><a name="a83"></a> <span class="src-str">'forUpdate' </span>=> <span class="src-id">false</span><span class="src-sym">,</span></div></li>
|
||
|
<li><div class="src-line"><a name="a84"></a> <span class="src-str">'from' </span>=> <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">,</span></div></li>
|
||
|
<li><div class="src-line"><a name="a85"></a> <span class="src-str">'set' </span>=> <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">,</span></div></li>
|
||
|
<li><div class="src-line"><a name="a86"></a> <span class="src-str">'join' </span>=> <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">,</span></div></li>
|
||
|
<li><div class="src-line"><a name="a87"></a> <span class="src-str">'where' </span>=> <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">,</span></div></li>
|
||
|
<li><div class="src-line"><a name="a88"></a> <span class="src-str">'groupby' </span>=> <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">,</span></div></li>
|
||
|
<li><div class="src-line"><a name="a89"></a> <span class="src-str">'having' </span>=> <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">,</span></div></li>
|
||
|
<li><div class="src-line"><a name="a90"></a> <span class="src-str">'orderby' </span>=> <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">,</span></div></li>
|
||
|
<li><div class="src-line"><a name="a91"></a> <span class="src-str">'limit' </span>=> <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">,</span></div></li>
|
||
|
<li><div class="src-line"><a name="a92"></a> <span class="src-str">'offset' </span>=> <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">,</span></div></li>
|
||
|
<li><div class="src-line"><a name="a93"></a> <span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a94"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a95"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@var </span><span class="src-doc-type">array </span><span class="src-doc-var">$_pendingJoinConditions </span><span class="src-doc"> an array containing pending joins</span></div></li>
|
||
|
<li><div class="src-line"><a name="a96"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a97"></a> <span class="src-key">protected </span><a href="../Doctrine/Doctrine_Query.html#var$_pendingJoinConditions">$_pendingJoinConditions</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a98"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a99"></a> <span class="src-key">protected </span><a href="../Doctrine/Doctrine_Query.html#var$_expressionMap">$_expressionMap</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a100"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a101"></a> <span class="src-key">protected </span><a href="../Doctrine/Doctrine_Query.html#var$_state">$_state</a> = <span class="src-id">Doctrine_Query</span><span class="src-sym">::</span><span class="src-id">STATE_CLEAN</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a102"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a103"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a104"></a><span class="src-doc"> * create</span></div></li>
|
||
|
<li><div class="src-line"><a name="a105"></a><span class="src-doc"> * returns a new Doctrine_Query object</span></div></li>
|
||
|
<li><div class="src-line"><a name="a106"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a107"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">Doctrine_Connection </span><span class="src-doc-var">$conn </span><span class="src-doc"> optional connection parameter</span></div></li>
|
||
|
<li><div class="src-line"><a name="a108"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">Doctrine_Query </span></div></li>
|
||
|
<li><div class="src-line"><a name="a109"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a110"></a> <span class="src-key">public </span><span class="src-key">static </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodcreate">create</a><span class="src-sym">(</span><span class="src-var">$conn </span>= <span class="src-id">null</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a111"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a112"></a> <span class="src-key">return </span><span class="src-key">new </span><span class="src-id"><a href="../Doctrine/Doctrine_Query.html">Doctrine_Query</a></span><span class="src-sym">(</span><span class="src-var">$conn</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a113"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a114"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodreset">reset</a><span class="src-sym">(</span><span class="src-sym">) </span></div></li>
|
||
|
<li><div class="src-line"><a name="a115"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a116"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_pendingJoinConditions">_pendingJoinConditions</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a117"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$pendingSubqueries">pendingSubqueries</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a118"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$pendingFields">pendingFields</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a119"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_neededTables">_neededTables</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a120"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_expressionMap">_expressionMap</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a121"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$subqueryAliases">subqueryAliases</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a122"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$needsSubquery">needsSubquery</a> = <span class="src-id">false</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a123"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$isLimitSubqueryUsed">isLimitSubqueryUsed</a> = <span class="src-id">false</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a124"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a125"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a126"></a><span class="src-doc"> * setOption</span></div></li>
|
||
|
<li><div class="src-line"><a name="a127"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a128"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$name </span><span class="src-doc"> option name</span></div></li>
|
||
|
<li><div class="src-line"><a name="a129"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$value </span><span class="src-doc"> option value</span></div></li>
|
||
|
<li><div class="src-line"><a name="a130"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">Doctrine_Query </span><span class="src-doc"> this object</span></div></li>
|
||
|
<li><div class="src-line"><a name="a131"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a132"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodsetOption">setOption</a><span class="src-sym">(</span><span class="src-var">$name</span><span class="src-sym">, </span><span class="src-var">$value</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a133"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a134"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span>isset<span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_options">_options</a><span class="src-sym">[</span><span class="src-var">$name</span><span class="src-sym">]</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a135"></a> throw <span class="src-key">new </span><span class="src-id"><a href="../Doctrine/Doctrine_Query_Exception.html">Doctrine_Query_Exception</a></span><span class="src-sym">(</span><span class="src-str">'Unknown option ' </span>. <span class="src-var">$name</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a136"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a137"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_options">_options</a><span class="src-sym">[</span><span class="src-var">$name</span><span class="src-sym">] </span>= <span class="src-var">$value</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a138"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a139"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a140"></a><span class="src-doc"> * addPendingJoinCondition</span></div></li>
|
||
|
<li><div class="src-line"><a name="a141"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a142"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$componentAlias </span><span class="src-doc"> component alias</span></div></li>
|
||
|
<li><div class="src-line"><a name="a143"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$joinCondition </span><span class="src-doc"> dql join condition</span></div></li>
|
||
|
<li><div class="src-line"><a name="a144"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">Doctrine_Query </span><span class="src-doc"> this object</span></div></li>
|
||
|
<li><div class="src-line"><a name="a145"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a146"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodaddPendingJoinCondition">addPendingJoinCondition</a><span class="src-sym">(</span><span class="src-var">$componentAlias</span><span class="src-sym">, </span><span class="src-var">$joinCondition</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a147"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a148"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-var">_pendingJoins</span><span class="src-sym">[</span><span class="src-var">$componentAlias</span><span class="src-sym">] </span>= <span class="src-var">$joinCondition</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a149"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a150"></a> <span class="src-doc">/** </span></div></li>
|
||
|
<li><div class="src-line"><a name="a151"></a><span class="src-doc"> * addEnumParam</span></div></li>
|
||
|
<li><div class="src-line"><a name="a152"></a><span class="src-doc"> * sets input parameter as an enumerated parameter</span></div></li>
|
||
|
<li><div class="src-line"><a name="a153"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a154"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$key </span><span class="src-doc"> the key of the input parameter</span></div></li>
|
||
|
<li><div class="src-line"><a name="a155"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">Doctrine_Query </span></div></li>
|
||
|
<li><div class="src-line"><a name="a156"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a157"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodaddEnumParam">addEnumParam</a><span class="src-sym">(</span><span class="src-var">$key</span><span class="src-sym">, </span><span class="src-var">$table </span>= <span class="src-id">null</span><span class="src-sym">, </span><span class="src-var">$column </span>= <span class="src-id">null</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a158"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a159"></a> <span class="src-var">$array </span>= <span class="src-sym">(</span>isset<span class="src-sym">(</span><span class="src-var">$table</span><span class="src-sym">) </span>|| isset<span class="src-sym">(</span><span class="src-var">$column</span><span class="src-sym">)) </span>? <span class="src-key">array</span><span class="src-sym">(</span><span class="src-var">$table</span><span class="src-sym">, </span><span class="src-var">$column</span><span class="src-sym">) </span>: <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a160"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a161"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$key </span>=== <span class="src-str">'?'</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a162"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_enumParams">_enumParams</a><span class="src-sym">[</span><span class="src-sym">] </span>= <span class="src-var">$array</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a163"></a> <span class="src-sym">} </span><span class="src-key">else </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a164"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_enumParams">_enumParams</a><span class="src-sym">[</span><span class="src-var">$key</span><span class="src-sym">] </span>= <span class="src-var">$array</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a165"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a166"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a167"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a168"></a><span class="src-doc"> * getEnumParams</span></div></li>
|
||
|
<li><div class="src-line"><a name="a169"></a><span class="src-doc"> * get all enumerated parameters</span></div></li>
|
||
|
<li><div class="src-line"><a name="a170"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a171"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">array </span><span class="src-doc"> all enumerated parameters</span></div></li>
|
||
|
<li><div class="src-line"><a name="a172"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a173"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodgetEnumParams">getEnumParams</a><span class="src-sym">(</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a174"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a175"></a> <span class="src-key">return </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_enumParams">_enumParams</a><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a176"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a177"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a178"></a><span class="src-doc"> * limitSubqueryUsed</span></div></li>
|
||
|
<li><div class="src-line"><a name="a179"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a180"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">boolean </span></div></li>
|
||
|
<li><div class="src-line"><a name="a181"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a182"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodisLimitSubqueryUsed">isLimitSubqueryUsed</a><span class="src-sym">(</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a183"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a184"></a> <span class="src-key">return </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$isLimitSubqueryUsed">isLimitSubqueryUsed</a><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a185"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a186"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a187"></a><span class="src-doc"> * convertEnums</span></div></li>
|
||
|
<li><div class="src-line"><a name="a188"></a><span class="src-doc"> * convert enum parameters to their integer equivalents</span></div></li>
|
||
|
<li><div class="src-line"><a name="a189"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a190"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">array </span><span class="src-doc"> converted parameter array</span></div></li>
|
||
|
<li><div class="src-line"><a name="a191"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a192"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodconvertEnums">convertEnums</a><span class="src-sym">(</span><span class="src-var">$params</span><span class="src-sym">) </span></div></li>
|
||
|
<li><div class="src-line"><a name="a193"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a194"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_enumParams">_enumParams</a> <span class="src-key">as </span><span class="src-var">$key </span>=> <span class="src-var">$values</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a195"></a> <span class="src-key">if </span><span class="src-sym">(</span>isset<span class="src-sym">(</span><span class="src-var">$params</span><span class="src-sym">[</span><span class="src-var">$key</span><span class="src-sym">]</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a196"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$values</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a197"></a> <span class="src-var">$params</span><span class="src-sym">[</span><span class="src-var">$key</span><span class="src-sym">] </span>= <span class="src-var">$values</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">-></span><span class="src-id">enumIndex</span><span class="src-sym">(</span><span class="src-var">$values</span><span class="src-sym">[</span><span class="src-num">1</span><span class="src-sym">]</span><span class="src-sym">, </span><span class="src-var">$params</span><span class="src-sym">[</span><span class="src-var">$key</span><span class="src-sym">]</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a198"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a199"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a200"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a201"></a> <span class="src-key">return </span><span class="src-var">$params</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a202"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a203"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a204"></a><span class="src-doc"> * isSubquery</span></div></li>
|
||
|
<li><div class="src-line"><a name="a205"></a><span class="src-doc"> * if $bool parameter is set this method sets the value of</span></div></li>
|
||
|
<li><div class="src-line"><a name="a206"></a><span class="src-doc"> * Doctrine_Query::$isSubquery. If this value is set to true</span></div></li>
|
||
|
<li><div class="src-line"><a name="a207"></a><span class="src-doc"> * the query object will not load the primary key fields of the selected</span></div></li>
|
||
|
<li><div class="src-line"><a name="a208"></a><span class="src-doc"> * components.</span></div></li>
|
||
|
<li><div class="src-line"><a name="a209"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a210"></a><span class="src-doc"> * If null is given as the first parameter this method retrieves the current</span></div></li>
|
||
|
<li><div class="src-line"><a name="a211"></a><span class="src-doc"> * value of Doctrine_Query::$isSubquery.</span></div></li>
|
||
|
<li><div class="src-line"><a name="a212"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a213"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">boolean </span><span class="src-doc-var">$bool </span><span class="src-doc"> whether or not this query acts as a subquery</span></div></li>
|
||
|
<li><div class="src-line"><a name="a214"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">Doctrine_Query</span><span class="src-doc">|</span><span class="src-doc-type">bool</span></div></li>
|
||
|
<li><div class="src-line"><a name="a215"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a216"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodisSubquery">isSubquery</a><span class="src-sym">(</span><span class="src-var">$bool </span>= <span class="src-id">null</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a217"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a218"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$bool </span>=== <span class="src-id">null</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a219"></a> <span class="src-key">return </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$isSubquery">isSubquery</a><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a220"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a221"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a222"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$isSubquery">isSubquery</a> = (bool) <span class="src-var">$bool</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a223"></a> <span class="src-key">return </span><span class="src-var">$this</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a224"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a225"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a226"></a><span class="src-doc"> * getAggregateAlias</span></div></li>
|
||
|
<li><div class="src-line"><a name="a227"></a><span class="src-doc"> * </span></div></li>
|
||
|
<li><div class="src-line"><a name="a228"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$dqlAlias </span><span class="src-doc"> the dql alias of an aggregate value</span></div></li>
|
||
|
<li><div class="src-line"><a name="a229"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">string </span></div></li>
|
||
|
<li><div class="src-line"><a name="a230"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a231"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodgetAggregateAlias">getAggregateAlias</a><span class="src-sym">(</span><span class="src-var">$dqlAlias</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a232"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a233"></a> <span class="src-key">if </span><span class="src-sym">(</span>isset<span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$aggregateMap">aggregateMap</a><span class="src-sym">[</span><span class="src-var">$dqlAlias</span><span class="src-sym">]</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a234"></a> <span class="src-comm">// mark the expression as used</span></div></li>
|
||
|
<li><div class="src-line"><a name="a235"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_expressionMap">_expressionMap</a><span class="src-sym">[</span><span class="src-var">$dqlAlias</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-num">1</span><span class="src-sym">] </span>= <span class="src-id">true</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a236"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a237"></a> <span class="src-key">return </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$aggregateMap">aggregateMap</a><span class="src-sym">[</span><span class="src-var">$dqlAlias</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a238"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a239"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$pendingAggregates">pendingAggregates</a><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a240"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodprocessPendingAggregates">processPendingAggregates</a><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a241"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a242"></a> <span class="src-key">return </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodgetAggregateAlias">getAggregateAlias</a><span class="src-sym">(</span><span class="src-var">$dqlAlias</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a243"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a244"></a> throw <span class="src-key">new </span><span class="src-id"><a href="../Doctrine/Doctrine_Query_Exception.html">Doctrine_Query_Exception</a></span><span class="src-sym">(</span><span class="src-str">'Unknown aggregate alias ' </span>. <span class="src-var">$dqlAlias</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a245"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a246"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a247"></a><span class="src-doc"> * getParser</span></div></li>
|
||
|
<li><div class="src-line"><a name="a248"></a><span class="src-doc"> * parser lazy-loader</span></div></li>
|
||
|
<li><div class="src-line"><a name="a249"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a250"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@throws</span><span class="src-doc"> Doctrine_Query_Exception if unknown parser name given</span></div></li>
|
||
|
<li><div class="src-line"><a name="a251"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">Doctrine_Query_Part </span></div></li>
|
||
|
<li><div class="src-line"><a name="a252"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a253"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodgetParser">getParser</a><span class="src-sym">(</span><span class="src-var">$name</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a254"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a255"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span>isset<span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_parsers">_parsers</a><span class="src-sym">[</span><span class="src-var">$name</span><span class="src-sym">]</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a256"></a> <span class="src-var">$class </span>= <span class="src-str">'Doctrine_Query_' </span>. <a href="http://www.php.net/ucwords">ucwords</a><span class="src-sym">(</span><a href="http://www.php.net/strtolower">strtolower</a><span class="src-sym">(</span><span class="src-var">$name</span><span class="src-sym">))</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a257"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a258"></a> <span class="src-id"><a href="../Doctrine/Doctrine.html">Doctrine</a></span><span class="src-sym">::</span><a href="../Doctrine/Doctrine.html#methodautoload">autoload</a><span class="src-sym">(</span><span class="src-var">$class</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a259"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a260"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span><a href="http://www.php.net/class_exists">class_exists</a><span class="src-sym">(</span><span class="src-var">$class</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a261"></a> throw <span class="src-key">new </span><span class="src-id"><a href="../Doctrine/Doctrine_Query_Exception.html">Doctrine_Query_Exception</a></span><span class="src-sym">(</span><span class="src-str">'Unknown parser ' </span>. <span class="src-var">$name</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a262"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a263"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a264"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_parsers">_parsers</a><span class="src-sym">[</span><span class="src-var">$name</span><span class="src-sym">] </span>= <span class="src-key">new </span><span class="src-var">$class</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a265"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a266"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a267"></a> <span class="src-key">return </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_parsers">_parsers</a><span class="src-sym">[</span><span class="src-var">$name</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a268"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a269"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a270"></a><span class="src-doc"> * parseQueryPart</span></div></li>
|
||
|
<li><div class="src-line"><a name="a271"></a><span class="src-doc"> * parses given DQL query part</span></div></li>
|
||
|
<li><div class="src-line"><a name="a272"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a273"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$queryPartName </span><span class="src-doc"> the name of the query part</span></div></li>
|
||
|
<li><div class="src-line"><a name="a274"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$queryPart </span><span class="src-doc"> query part to be parsed</span></div></li>
|
||
|
<li><div class="src-line"><a name="a275"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">boolean </span><span class="src-doc-var">$append </span><span class="src-doc"> whether or not to append the query part to its stack</span></div></li>
|
||
|
<li><div class="src-line"><a name="a276"></a><span class="src-doc"> * if false is given, this method will overwrite</span></div></li>
|
||
|
<li><div class="src-line"><a name="a277"></a><span class="src-doc"> * the given query part stack with $queryPart</span></div></li>
|
||
|
<li><div class="src-line"><a name="a278"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">Doctrine_Query </span><span class="src-doc"> this object</span></div></li>
|
||
|
<li><div class="src-line"><a name="a279"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a280"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodparseQueryPart">parseQueryPart</a><span class="src-sym">(</span><span class="src-var">$queryPartName</span><span class="src-sym">, </span><span class="src-var">$queryPart</span><span class="src-sym">, </span><span class="src-var">$append </span>= <span class="src-id">false</span><span class="src-sym">) </span></div></li>
|
||
|
<li><div class="src-line"><a name="a281"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a282"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_state">_state</a> === <span class="src-id">self</span><span class="src-sym">::</span><span class="src-id">STATE_LOCKED</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a283"></a> throw <span class="src-key">new </span><span class="src-id"><a href="../Doctrine/Doctrine_Query_Exception.html">Doctrine_Query_Exception</a></span><span class="src-sym">(</span><span class="src-str">'This query object is locked. No query parts can be manipulated.'</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a284"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a285"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a286"></a> <span class="src-comm">// sanity check</span></div></li>
|
||
|
<li><div class="src-line"><a name="a287"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$queryPart </span>=== <span class="src-str">'' </span>|| <span class="src-var">$queryPart </span>=== <span class="src-id">null</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a288"></a> throw <span class="src-key">new </span><span class="src-id"><a href="../Doctrine/Doctrine_Query_Exception.html">Doctrine_Query_Exception</a></span><span class="src-sym">(</span><span class="src-str">'Empty ' </span>. <span class="src-var">$queryPartName </span>. <span class="src-str">' part given.'</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a289"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a290"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a291"></a> <span class="src-comm">// add query part to the dql part array</span></div></li>
|
||
|
<li><div class="src-line"><a name="a292"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$append</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a293"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a><span class="src-sym">[</span><span class="src-var">$queryPartName</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-sym">] </span>= <span class="src-var">$queryPart</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a294"></a> <span class="src-sym">} </span><span class="src-key">else </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a295"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a><span class="src-sym">[</span><span class="src-var">$queryPartName</span><span class="src-sym">] </span>= <span class="src-key">array</span><span class="src-sym">(</span><span class="src-var">$queryPart</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a296"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a297"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a298"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_state">_state</a> === <span class="src-id">self</span><span class="src-sym">::</span><span class="src-id">STATE_DIRECT</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a299"></a> <span class="src-var">$parser </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodgetParser">getParser</a><span class="src-sym">(</span><span class="src-var">$queryPartName</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a300"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a301"></a> <span class="src-var">$sql </span>= <span class="src-var">$parser</span><span class="src-sym">-></span><span class="src-id">parse</span><span class="src-sym">(</span><span class="src-var">$queryPart</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a302"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a303"></a> <span class="src-key">if </span><span class="src-sym">(</span>isset<span class="src-sym">(</span><span class="src-var">$sql</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a304"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$append</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a305"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodaddQueryPart">addQueryPart</a><span class="src-sym">(</span><span class="src-var">$queryPartName</span><span class="src-sym">, </span><span class="src-var">$sql</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a306"></a> <span class="src-sym">} </span><span class="src-key">else </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a307"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodsetQueryPart">setQueryPart</a><span class="src-sym">(</span><span class="src-var">$queryPartName</span><span class="src-sym">, </span><span class="src-var">$sql</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a308"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a309"></a> <span class="src-sym">} </span></div></li>
|
||
|
<li><div class="src-line"><a name="a310"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a311"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a312"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_state">_state</a> = <span class="src-id"><a href="../Doctrine/Doctrine_Query.html">Doctrine_Query</a></span><span class="src-sym">::</span><span class="src-id">STATE_DIRTY</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a313"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a314"></a> <span class="src-key">return </span><span class="src-var">$this</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a315"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a316"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a317"></a><span class="src-doc"> * getDqlPart</span></div></li>
|
||
|
<li><div class="src-line"><a name="a318"></a><span class="src-doc"> * returns the given DQL query part</span></div></li>
|
||
|
<li><div class="src-line"><a name="a319"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a320"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$queryPart </span><span class="src-doc"> the name of the query part</span></div></li>
|
||
|
<li><div class="src-line"><a name="a321"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">string </span><span class="src-doc"> the DQL query part</span></div></li>
|
||
|
<li><div class="src-line"><a name="a322"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a323"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodgetDqlPart">getDqlPart</a><span class="src-sym">(</span><span class="src-var">$queryPart</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a324"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a325"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span>isset<span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a><span class="src-sym">[</span><span class="src-var">$queryPart</span><span class="src-sym">]</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a326"></a> throw <span class="src-key">new </span><span class="src-id"><a href="../Doctrine/Doctrine_Query_Exception.html">Doctrine_Query_Exception</a></span><span class="src-sym">(</span><span class="src-str">'Unknown query part ' </span>. <span class="src-var">$queryPart</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a327"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a328"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a329"></a> <span class="src-key">return </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a><span class="src-sym">[</span><span class="src-var">$queryPart</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a330"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a331"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a332"></a><span class="src-doc"> * getDql</span></div></li>
|
||
|
<li><div class="src-line"><a name="a333"></a><span class="src-doc"> * returns the DQL query associated with this object</span></div></li>
|
||
|
<li><div class="src-line"><a name="a334"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a335"></a><span class="src-doc"> * the query is built from $_dqlParts</span></div></li>
|
||
|
<li><div class="src-line"><a name="a336"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a337"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">string </span><span class="src-doc"> the DQL query</span></div></li>
|
||
|
<li><div class="src-line"><a name="a338"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a339"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodgetDql">getDql</a><span class="src-sym">(</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a340"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a341"></a> <span class="src-var">$q </span>= <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a342"></a> <span class="src-var">$q </span>.= <span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a><span class="src-sym">[</span><span class="src-str">'select'</span><span class="src-sym">]</span><span class="src-sym">))</span>? <span class="src-str">'SELECT ' </span>. <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">', '</span><span class="src-sym">, </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a><span class="src-sym">[</span><span class="src-str">'select'</span><span class="src-sym">]</span><span class="src-sym">) </span>: <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a343"></a> <span class="src-var">$q </span>.= <span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a><span class="src-sym">[</span><span class="src-str">'from'</span><span class="src-sym">]</span><span class="src-sym">))</span>? <span class="src-str">' FROM ' </span>. <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">' '</span><span class="src-sym">, </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a><span class="src-sym">[</span><span class="src-str">'from'</span><span class="src-sym">]</span><span class="src-sym">) </span>: <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a344"></a> <span class="src-var">$q </span>.= <span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a><span class="src-sym">[</span><span class="src-str">'where'</span><span class="src-sym">]</span><span class="src-sym">))</span>? <span class="src-str">' WHERE ' </span>. <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">' AND '</span><span class="src-sym">, </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a><span class="src-sym">[</span><span class="src-str">'where'</span><span class="src-sym">]</span><span class="src-sym">) </span>: <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a345"></a> <span class="src-var">$q </span>.= <span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a><span class="src-sym">[</span><span class="src-str">'groupby'</span><span class="src-sym">]</span><span class="src-sym">))</span>? <span class="src-str">' GROUP BY ' </span>. <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">', '</span><span class="src-sym">, </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a><span class="src-sym">[</span><span class="src-str">'groupby'</span><span class="src-sym">]</span><span class="src-sym">) </span>: <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a346"></a> <span class="src-var">$q </span>.= <span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a><span class="src-sym">[</span><span class="src-str">'having'</span><span class="src-sym">]</span><span class="src-sym">))</span>? <span class="src-str">' HAVING ' </span>. <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">' AND '</span><span class="src-sym">, </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a><span class="src-sym">[</span><span class="src-str">'having'</span><span class="src-sym">]</span><span class="src-sym">) </span>: <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a347"></a> <span class="src-var">$q </span>.= <span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a><span class="src-sym">[</span><span class="src-str">'orderby'</span><span class="src-sym">]</span><span class="src-sym">))</span>? <span class="src-str">' ORDER BY ' </span>. <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">', '</span><span class="src-sym">, </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a><span class="src-sym">[</span><span class="src-str">'orderby'</span><span class="src-sym">]</span><span class="src-sym">) </span>: <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a348"></a> <span class="src-var">$q </span>.= <span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a><span class="src-sym">[</span><span class="src-str">'limit'</span><span class="src-sym">]</span><span class="src-sym">))</span>? <span class="src-str">' LIMIT ' </span>. <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">' '</span><span class="src-sym">, </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a><span class="src-sym">[</span><span class="src-str">'limit'</span><span class="src-sym">]</span><span class="src-sym">) </span>: <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a349"></a> <span class="src-var">$q </span>.= <span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a><span class="src-sym">[</span><span class="src-str">'offset'</span><span class="src-sym">]</span><span class="src-sym">))</span>? <span class="src-str">' OFFSET ' </span>. <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">' '</span><span class="src-sym">, </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a><span class="src-sym">[</span><span class="src-str">'offset'</span><span class="src-sym">]</span><span class="src-sym">) </span>: <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a350"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a351"></a> <span class="src-key">return </span><span class="src-var">$q</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a352"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a353"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a354"></a><span class="src-doc"> * processPendingFields</span></div></li>
|
||
|
<li><div class="src-line"><a name="a355"></a><span class="src-doc"> * the fields in SELECT clause cannot be parsed until the components</span></div></li>
|
||
|
<li><div class="src-line"><a name="a356"></a><span class="src-doc"> * in FROM clause are parsed, hence this method is called everytime a</span></div></li>
|
||
|
<li><div class="src-line"><a name="a357"></a><span class="src-doc"> * specific component is being parsed.</span></div></li>
|
||
|
<li><div class="src-line"><a name="a358"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a359"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@throws</span><span class="src-doc"> Doctrine_Query_Exception if unknown component alias has been given</span></div></li>
|
||
|
<li><div class="src-line"><a name="a360"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$componentAlias </span><span class="src-doc"> the alias of the component</span></div></li>
|
||
|
<li><div class="src-line"><a name="a361"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">void </span></div></li>
|
||
|
<li><div class="src-line"><a name="a362"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a363"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodprocessPendingFields">processPendingFields</a><span class="src-sym">(</span><span class="src-var">$componentAlias</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a364"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a365"></a> <span class="src-var">$tableAlias </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodgetTableAlias">getTableAlias</a><span class="src-sym">(</span><span class="src-var">$componentAlias</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a366"></a> <span class="src-var">$table </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_aliasMap">_aliasMap</a><span class="src-sym">[</span><span class="src-var">$componentAlias</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-str">'table'</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a367"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a368"></a> <span class="src-key">if </span><span class="src-sym">(</span>isset<span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$pendingFields">pendingFields</a><span class="src-sym">[</span><span class="src-var">$componentAlias</span><span class="src-sym">]</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a369"></a> <span class="src-var">$fields </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$pendingFields">pendingFields</a><span class="src-sym">[</span><span class="src-var">$componentAlias</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a370"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a371"></a> <span class="src-comm">// check for wildcards</span></div></li>
|
||
|
<li><div class="src-line"><a name="a372"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/in_array">in_array</a><span class="src-sym">(</span><span class="src-str">'*'</span><span class="src-sym">, </span><span class="src-var">$fields</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a373"></a> <span class="src-var">$fields </span>= <span class="src-var">$table</span><span class="src-sym">-></span><span class="src-id">getColumnNames</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a374"></a> <span class="src-sym">} </span><span class="src-key">else </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a375"></a> <span class="src-comm">// only auto-add the primary key fields if this query object is not </span></div></li>
|
||
|
<li><div class="src-line"><a name="a376"></a> <span class="src-comm">// a subquery of another query object</span></div></li>
|
||
|
<li><div class="src-line"><a name="a377"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$isSubquery">isSubquery</a><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a378"></a> <span class="src-var">$fields </span>= <a href="http://www.php.net/array_unique">array_unique</a><span class="src-sym">(</span><a href="http://www.php.net/array_merge">array_merge</a><span class="src-sym">(</span><span class="src-var">$table</span><span class="src-sym">-></span><span class="src-id">getPrimaryKeys</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">, </span><span class="src-var">$fields</span><span class="src-sym">))</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a379"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a380"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a381"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a382"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-var">$fields </span><span class="src-key">as </span><span class="src-var">$name</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a383"></a> <span class="src-var">$name </span>= <span class="src-var">$table</span><span class="src-sym">-></span><span class="src-id">getColumnName</span><span class="src-sym">(</span><span class="src-var">$name</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a384"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a385"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'select'</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-sym">] </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$tableAlias </span>. <span class="src-str">'.' </span>. <span class="src-var">$name</span><span class="src-sym">) </span></div></li>
|
||
|
<li><div class="src-line"><a name="a386"></a> . <span class="src-str">' AS ' </span></div></li>
|
||
|
<li><div class="src-line"><a name="a387"></a> . <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$tableAlias </span>. <span class="src-str">'__' </span>. <span class="src-var">$name</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a388"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a389"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a390"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-var">neededTables</span><span class="src-sym">[</span><span class="src-sym">] </span>= <span class="src-var">$tableAlias</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a391"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a392"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a393"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a394"></a><span class="src-doc"> * parseSelect</span></div></li>
|
||
|
<li><div class="src-line"><a name="a395"></a><span class="src-doc"> * parses the query select part and</span></div></li>
|
||
|
<li><div class="src-line"><a name="a396"></a><span class="src-doc"> * adds selected fields to pendingFields array</span></div></li>
|
||
|
<li><div class="src-line"><a name="a397"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a398"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$dql </span></div></li>
|
||
|
<li><div class="src-line"><a name="a399"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a400"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodparseSelect">parseSelect</a><span class="src-sym">(</span><span class="src-var">$dql</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a401"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a402"></a> <span class="src-var">$refs </span>= <span class="src-id"><a href="../Doctrine/Doctrine_Tokenizer.html">Doctrine_Tokenizer</a></span><span class="src-sym">::</span><a href="../Doctrine/Doctrine_Tokenizer.html#methodbracketExplode">bracketExplode</a><span class="src-sym">(</span><span class="src-var">$dql</span><span class="src-sym">, </span><span class="src-str">','</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a403"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a404"></a> <span class="src-var">$pos </span>= <a href="http://www.php.net/strpos">strpos</a><span class="src-sym">(</span><a href="http://www.php.net/trim">trim</a><span class="src-sym">(</span><span class="src-var">$refs</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">)</span><span class="src-sym">, </span><span class="src-str">' '</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a405"></a> <span class="src-var">$first </span>= <a href="http://www.php.net/substr">substr</a><span class="src-sym">(</span><span class="src-var">$refs</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">, </span><span class="src-num">0</span><span class="src-sym">, </span><span class="src-var">$pos</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a406"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a407"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$first </span>=== <span class="src-str">'DISTINCT'</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a408"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'distinct'</span><span class="src-sym">] </span>= <span class="src-id">true</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a409"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a410"></a> <span class="src-var">$refs</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">] </span>= <a href="http://www.php.net/substr">substr</a><span class="src-sym">(</span><span class="src-var">$refs</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">, </span>++<span class="src-var">$pos</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a411"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a412"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a413"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-var">$refs </span><span class="src-key">as </span><span class="src-var">$reference</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a414"></a> <span class="src-var">$reference </span>= <a href="http://www.php.net/trim">trim</a><span class="src-sym">(</span><span class="src-var">$reference</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a415"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/strpos">strpos</a><span class="src-sym">(</span><span class="src-var">$reference</span><span class="src-sym">, </span><span class="src-str">'('</span><span class="src-sym">) </span>!== <span class="src-id">false</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a416"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/substr">substr</a><span class="src-sym">(</span><span class="src-var">$reference</span><span class="src-sym">, </span><span class="src-num">0</span><span class="src-sym">, </span><span class="src-num">1</span><span class="src-sym">) </span>=== <span class="src-str">'('</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a417"></a> <span class="src-comm">// subselect found in SELECT part</span></div></li>
|
||
|
<li><div class="src-line"><a name="a418"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodparseSubselect">parseSubselect</a><span class="src-sym">(</span><span class="src-var">$reference</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a419"></a> <span class="src-sym">} </span><span class="src-key">else </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a420"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodparseAggregateFunction">parseAggregateFunction</a><span class="src-sym">(</span><span class="src-var">$reference</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a421"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a422"></a> <span class="src-sym">} </span><span class="src-key">else </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a423"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a424"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a425"></a> <span class="src-var">$e </span>= <a href="http://www.php.net/explode">explode</a><span class="src-sym">(</span><span class="src-str">'.'</span><span class="src-sym">, </span><span class="src-var">$reference</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a426"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="../Doctrine/Doctrine_Query.html#methodcount">count</a><span class="src-sym">(</span><span class="src-var">$e</span><span class="src-sym">) </span>> <span class="src-num">2</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a427"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$pendingFields">pendingFields</a><span class="src-sym">[</span><span class="src-sym">] </span>= <span class="src-var">$reference</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a428"></a> <span class="src-sym">} </span><span class="src-key">else </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a429"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$pendingFields">pendingFields</a><span class="src-sym">[</span><span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]]</span><span class="src-sym">[</span><span class="src-sym">] </span>= <span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">1</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a430"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a431"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a432"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a433"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a434"></a> <span class="src-doc">/** </span></div></li>
|
||
|
<li><div class="src-line"><a name="a435"></a><span class="src-doc"> * parseSubselect</span></div></li>
|
||
|
<li><div class="src-line"><a name="a436"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a437"></a><span class="src-doc"> * parses the subquery found in DQL SELECT part and adds the</span></div></li>
|
||
|
<li><div class="src-line"><a name="a438"></a><span class="src-doc"> * parsed form into $pendingSubqueries stack</span></div></li>
|
||
|
<li><div class="src-line"><a name="a439"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a440"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$reference </span></div></li>
|
||
|
<li><div class="src-line"><a name="a441"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">void </span></div></li>
|
||
|
<li><div class="src-line"><a name="a442"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a443"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodparseSubselect">parseSubselect</a><span class="src-sym">(</span><span class="src-var">$reference</span><span class="src-sym">) </span></div></li>
|
||
|
<li><div class="src-line"><a name="a444"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a445"></a> <span class="src-var">$e </span>= <span class="src-id"><a href="../Doctrine/Doctrine_Tokenizer.html">Doctrine_Tokenizer</a></span><span class="src-sym">::</span><a href="../Doctrine/Doctrine_Tokenizer.html#methodbracketExplode">bracketExplode</a><span class="src-sym">(</span><span class="src-var">$reference</span><span class="src-sym">, </span><span class="src-str">' '</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a446"></a> <span class="src-var">$alias </span>= <span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">1</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a447"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a448"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="../Doctrine/Doctrine_Query.html#methodcount">count</a><span class="src-sym">(</span><span class="src-var">$e</span><span class="src-sym">) </span>> <span class="src-num">2</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a449"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/strtoupper">strtoupper</a><span class="src-sym">(</span><span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">1</span><span class="src-sym">]</span><span class="src-sym">) </span>!== <span class="src-str">'AS'</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a450"></a> throw <span class="src-key">new </span><span class="src-id"><a href="../Doctrine/Doctrine_Query_Exception.html">Doctrine_Query_Exception</a></span><span class="src-sym">(</span><span class="src-str">'Syntax error near: ' </span>. <span class="src-var">$reference</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a451"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a452"></a> <span class="src-var">$alias </span>= <span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">2</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a453"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a454"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a455"></a> <span class="src-var">$subquery </span>= <a href="http://www.php.net/substr">substr</a><span class="src-sym">(</span><span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">, </span><span class="src-num">1</span><span class="src-sym">, </span>-<span class="src-num">1</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a456"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a457"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$pendingSubqueries">pendingSubqueries</a><span class="src-sym">[</span><span class="src-sym">] </span>= <span class="src-key">array</span><span class="src-sym">(</span><span class="src-var">$subquery</span><span class="src-sym">, </span><span class="src-var">$alias</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a458"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a459"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a460"></a><span class="src-doc"> * parseClause</span></div></li>
|
||
|
<li><div class="src-line"><a name="a461"></a><span class="src-doc"> * parses given DQL clause</span></div></li>
|
||
|
<li><div class="src-line"><a name="a462"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a463"></a><span class="src-doc"> * this method handles five tasks:</span></div></li>
|
||
|
<li><div class="src-line"><a name="a464"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a465"></a><span class="src-doc"> * 1. Converts all DQL functions to their native SQL equivalents</span></div></li>
|
||
|
<li><div class="src-line"><a name="a466"></a><span class="src-doc"> * 2. Converts all component references to their table alias equivalents</span></div></li>
|
||
|
<li><div class="src-line"><a name="a467"></a><span class="src-doc"> * 3. Converts all column aliases to actual column names</span></div></li>
|
||
|
<li><div class="src-line"><a name="a468"></a><span class="src-doc"> * 4. Quotes all identifiers</span></div></li>
|
||
|
<li><div class="src-line"><a name="a469"></a><span class="src-doc"> * 5. Parses nested clauses and subqueries recursively</span></div></li>
|
||
|
<li><div class="src-line"><a name="a470"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a471"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">string </span><span class="src-doc"> SQL string</span></div></li>
|
||
|
<li><div class="src-line"><a name="a472"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a473"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodparseClause">parseClause</a><span class="src-sym">(</span><span class="src-var">$clause</span><span class="src-sym">) </span></div></li>
|
||
|
<li><div class="src-line"><a name="a474"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a475"></a> <span class="src-var">$terms </span>= <span class="src-id"><a href="../Doctrine/Doctrine_Tokenizer.html">Doctrine_Tokenizer</a></span><span class="src-sym">::</span><a href="../Doctrine/Doctrine_Tokenizer.html#methodclauseExplode">clauseExplode</a><span class="src-sym">(</span><span class="src-var">$clause</span><span class="src-sym">, </span><span class="src-key">array</span><span class="src-sym">(</span><span class="src-str">' '</span><span class="src-sym">, </span><span class="src-str">'+'</span><span class="src-sym">, </span><span class="src-str">'-'</span><span class="src-sym">, </span><span class="src-str">'*'</span><span class="src-sym">, </span><span class="src-str">'/'</span><span class="src-sym">))</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a476"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a477"></a> <span class="src-var">$str </span>= <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a478"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-var">$terms </span><span class="src-key">as </span><span class="src-var">$term</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a479"></a> <span class="src-var">$pos </span>= <a href="http://www.php.net/strpos">strpos</a><span class="src-sym">(</span><span class="src-var">$term</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">, </span><span class="src-str">'('</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a480"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a481"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$pos </span>!== <span class="src-id">false</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a482"></a> <span class="src-var">$name </span>= <a href="http://www.php.net/substr">substr</a><span class="src-sym">(</span><span class="src-var">$term</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">, </span><span class="src-num">0</span><span class="src-sym">, </span><span class="src-var">$pos</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a483"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$name </span>!== <span class="src-str">''</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a484"></a> <span class="src-var">$argStr </span>= <a href="http://www.php.net/substr">substr</a><span class="src-sym">(</span><span class="src-var">$term</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">, </span><span class="src-sym">(</span><span class="src-var">$pos </span>+ <span class="src-num">1</span><span class="src-sym">)</span><span class="src-sym">, </span>-<span class="src-num">1</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a485"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a486"></a> <span class="src-var">$args </span>= <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a487"></a> <span class="src-comm">// parse args</span></div></li>
|
||
|
<li><div class="src-line"><a name="a488"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a489"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-id"><a href="../Doctrine/Doctrine_Tokenizer.html">Doctrine_Tokenizer</a></span><span class="src-sym">::</span><a href="../Doctrine/Doctrine_Tokenizer.html#methodsqlExplode">sqlExplode</a><span class="src-sym">(</span><span class="src-var">$argStr</span><span class="src-sym">, </span><span class="src-str">','</span><span class="src-sym">) </span><span class="src-key">as </span><span class="src-var">$expr</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a490"></a> <span class="src-var">$args</span><span class="src-sym">[</span><span class="src-sym">] </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodparseClause">parseClause</a><span class="src-sym">(</span><span class="src-var">$expr</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a491"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a492"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a493"></a> <span class="src-comm">// convert DQL function to its RDBMS specific equivalent</span></div></li>
|
||
|
<li><div class="src-line"><a name="a494"></a> try <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a495"></a> <span class="src-var">$expr </span>= <a href="http://www.php.net/call_user_func_array">call_user_func_array</a><span class="src-sym">(</span><span class="src-key">array</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">expression</span><span class="src-sym">, </span><span class="src-var">$name</span><span class="src-sym">)</span><span class="src-sym">, </span><span class="src-var">$args</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a496"></a> <span class="src-sym">} </span>catch<span class="src-sym">(</span><span class="src-id"><a href="../Doctrine/Doctrine_Expression_Exception.html">Doctrine_Expression_Exception</a> </span><span class="src-var">$e</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a497"></a> throw <span class="src-key">new </span><span class="src-id"><a href="../Doctrine/Doctrine_Query_Exception.html">Doctrine_Query_Exception</a></span><span class="src-sym">(</span><span class="src-str">'Unknown function ' </span>. <span class="src-var">$func </span>. <span class="src-str">'.'</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a498"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a499"></a> <span class="src-var">$term</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">] </span>= <span class="src-var">$expr</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a500"></a> <span class="src-sym">} </span><span class="src-key">else </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a501"></a> <span class="src-var">$trimmed </span>= <a href="http://www.php.net/trim">trim</a><span class="src-sym">(</span><span class="src-id"><a href="../Doctrine/Doctrine_Tokenizer.html">Doctrine_Tokenizer</a></span><span class="src-sym">::</span><a href="../Doctrine/Doctrine_Tokenizer.html#methodbracketTrim">bracketTrim</a><span class="src-sym">(</span><span class="src-var">$term</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">))</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a502"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a503"></a> <span class="src-comm">// check for possible subqueries</span></div></li>
|
||
|
<li><div class="src-line"><a name="a504"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/substr">substr</a><span class="src-sym">(</span><span class="src-var">$trimmed</span><span class="src-sym">, </span><span class="src-num">0</span><span class="src-sym">, </span><span class="src-num">4</span><span class="src-sym">) </span>== <span class="src-str">'FROM' </span>|| <a href="http://www.php.net/substr">substr</a><span class="src-sym">(</span><span class="src-var">$trimmed</span><span class="src-sym">, </span><span class="src-num">0</span><span class="src-sym">, </span><span class="src-num">6</span><span class="src-sym">) </span>== <span class="src-str">'SELECT'</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a505"></a> <span class="src-comm">// parse subquery</span></div></li>
|
||
|
<li><div class="src-line"><a name="a506"></a> <span class="src-var">$trimmed </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodcreateSubquery">createSubquery</a><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">-></span><span class="src-id">parseQuery</span><span class="src-sym">(</span><span class="src-var">$trimmed</span><span class="src-sym">)</span><span class="src-sym">-></span><span class="src-id">getQuery</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a507"></a> <span class="src-sym">} </span><span class="src-key">else </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a508"></a> <span class="src-comm">// parse normal clause</span></div></li>
|
||
|
<li><div class="src-line"><a name="a509"></a> <span class="src-var">$trimmed </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodparseClause">parseClause</a><span class="src-sym">(</span><span class="src-var">$trimmed</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a510"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a511"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a512"></a> <span class="src-var">$term</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">] </span>= <span class="src-str">'(' </span>. <span class="src-var">$trimmed </span>. <span class="src-str">')'</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a513"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a514"></a> <span class="src-sym">} </span><span class="src-key">else </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a515"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/substr">substr</a><span class="src-sym">(</span><span class="src-var">$term</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">, </span><span class="src-num">0</span><span class="src-sym">, </span><span class="src-num">1</span><span class="src-sym">) </span>!== <span class="src-str">"'" </span>&& <a href="http://www.php.net/substr">substr</a><span class="src-sym">(</span><span class="src-var">$term</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">, </span>-<span class="src-num">1</span><span class="src-sym">) </span>!== <span class="src-str">"'"</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a516"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/strpos">strpos</a><span class="src-sym">(</span><span class="src-var">$term</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">, </span><span class="src-str">'.'</span><span class="src-sym">) </span>!== <span class="src-id">false</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a517"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span><a href="http://www.php.net/is_numeric">is_numeric</a><span class="src-sym">(</span><span class="src-var">$term</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a518"></a> <span class="src-var">$e </span>= <a href="http://www.php.net/explode">explode</a><span class="src-sym">(</span><span class="src-str">'.'</span><span class="src-sym">, </span><span class="src-var">$term</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a519"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a520"></a> <span class="src-var">$field </span>= <a href="http://www.php.net/array_pop">array_pop</a><span class="src-sym">(</span><span class="src-var">$e</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a521"></a> <span class="src-var">$componentAlias </span>= <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">'.'</span><span class="src-sym">, </span><span class="src-var">$e</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a522"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a523"></a> <span class="src-comm">// check the existence of the component alias</span></div></li>
|
||
|
<li><div class="src-line"><a name="a524"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span>isset<span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_aliasMap">_aliasMap</a><span class="src-sym">[</span><span class="src-var">$componentAlias</span><span class="src-sym">]</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a525"></a> throw <span class="src-key">new </span><span class="src-id"><a href="../Doctrine/Doctrine_Query_Exception.html">Doctrine_Query_Exception</a></span><span class="src-sym">(</span><span class="src-str">'Unknown component alias ' </span>. <span class="src-var">$componentAlias</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a526"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a527"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a528"></a> <span class="src-var">$table </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_aliasMap">_aliasMap</a><span class="src-sym">[</span><span class="src-var">$componentAlias</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-str">'table'</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a529"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a530"></a> <span class="src-comm">// get the actual field name from alias</span></div></li>
|
||
|
<li><div class="src-line"><a name="a531"></a> <span class="src-var">$field </span>= <span class="src-var">$table</span><span class="src-sym">-></span><span class="src-id">getColumnName</span><span class="src-sym">(</span><span class="src-var">$field</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a532"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a533"></a> <span class="src-comm">// check column existence</span></div></li>
|
||
|
<li><div class="src-line"><a name="a534"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span><span class="src-var">$table</span><span class="src-sym">-></span><span class="src-id">hasColumn</span><span class="src-sym">(</span><span class="src-var">$field</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a535"></a> throw <span class="src-key">new </span><span class="src-id"><a href="../Doctrine/Doctrine_Query_Exception.html">Doctrine_Query_Exception</a></span><span class="src-sym">(</span><span class="src-str">'Unknown column ' </span>. <span class="src-var">$field</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a536"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a537"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a538"></a> <span class="src-var">$tableAlias </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodgetTableAlias">getTableAlias</a><span class="src-sym">(</span><span class="src-var">$componentAlias</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a539"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a540"></a> <span class="src-comm">// build sql expression</span></div></li>
|
||
|
<li><div class="src-line"><a name="a541"></a> <span class="src-var">$term</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">] </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$tableAlias</span><span class="src-sym">) </span></div></li>
|
||
|
<li><div class="src-line"><a name="a542"></a> . <span class="src-str">'.' </span></div></li>
|
||
|
<li><div class="src-line"><a name="a543"></a> . <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$field</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a544"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a545"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a546"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a547"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a548"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a549"></a> <span class="src-var">$str </span>.= <span class="src-var">$term</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">] </span>. <span class="src-var">$term</span><span class="src-sym">[</span><span class="src-num">1</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a550"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a551"></a> <span class="src-key">return </span><span class="src-var">$str</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a552"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a553"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a554"></a><span class="src-doc"> * parseAggregateFunction</span></div></li>
|
||
|
<li><div class="src-line"><a name="a555"></a><span class="src-doc"> * parses an aggregate function and returns the parsed form</span></div></li>
|
||
|
<li><div class="src-line"><a name="a556"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a557"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@see</span><span class="src-doc"> Doctrine_Expression</span></div></li>
|
||
|
<li><div class="src-line"><a name="a558"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$expr </span><span class="src-doc"> DQL aggregate function</span></div></li>
|
||
|
<li><div class="src-line"><a name="a559"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@throws</span><span class="src-doc"> Doctrine_Query_Exception if unknown aggregate function given</span></div></li>
|
||
|
<li><div class="src-line"><a name="a560"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">array </span><span class="src-doc"> parsed form of given function</span></div></li>
|
||
|
<li><div class="src-line"><a name="a561"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a562"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodparseAggregateFunction">parseAggregateFunction</a><span class="src-sym">(</span><span class="src-var">$expr</span><span class="src-sym">, </span><span class="src-var">$nestedCall </span>= <span class="src-id">false</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a563"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a564"></a> <span class="src-var">$e </span>= <span class="src-id"><a href="../Doctrine/Doctrine_Tokenizer.html">Doctrine_Tokenizer</a></span><span class="src-sym">::</span><a href="../Doctrine/Doctrine_Tokenizer.html#methodbracketExplode">bracketExplode</a><span class="src-sym">(</span><span class="src-var">$expr</span><span class="src-sym">, </span><span class="src-str">' '</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a565"></a> <span class="src-var">$func </span>= <span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a566"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a567"></a> <span class="src-var">$pos </span>= <a href="http://www.php.net/strpos">strpos</a><span class="src-sym">(</span><span class="src-var">$func</span><span class="src-sym">, </span><span class="src-str">'('</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a568"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$pos </span>=== <span class="src-id">false</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a569"></a> <span class="src-key">return </span><span class="src-var">$expr</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a570"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a571"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a572"></a> <span class="src-comm">// get the name of the function</span></div></li>
|
||
|
<li><div class="src-line"><a name="a573"></a> <span class="src-var">$name </span>= <a href="http://www.php.net/substr">substr</a><span class="src-sym">(</span><span class="src-var">$func</span><span class="src-sym">, </span><span class="src-num">0</span><span class="src-sym">, </span><span class="src-var">$pos</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a574"></a> <span class="src-var">$argStr </span>= <a href="http://www.php.net/substr">substr</a><span class="src-sym">(</span><span class="src-var">$func</span><span class="src-sym">, </span><span class="src-sym">(</span><span class="src-var">$pos </span>+ <span class="src-num">1</span><span class="src-sym">)</span><span class="src-sym">, </span>-<span class="src-num">1</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a575"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a576"></a> <span class="src-var">$args </span>= <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a577"></a> <span class="src-comm">// parse args</span></div></li>
|
||
|
<li><div class="src-line"><a name="a578"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-id"><a href="../Doctrine/Doctrine_Tokenizer.html">Doctrine_Tokenizer</a></span><span class="src-sym">::</span><a href="../Doctrine/Doctrine_Tokenizer.html#methodbracketExplode">bracketExplode</a><span class="src-sym">(</span><span class="src-var">$argStr</span><span class="src-sym">, </span><span class="src-str">','</span><span class="src-sym">) </span><span class="src-key">as </span><span class="src-var">$expr</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a579"></a> <span class="src-var">$args</span><span class="src-sym">[</span><span class="src-sym">] </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodparseAggregateFunction">parseAggregateFunction</a><span class="src-sym">(</span><span class="src-var">$expr</span><span class="src-sym">, </span><span class="src-id">true</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a580"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a581"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a582"></a> <span class="src-comm">// convert DQL function to its RDBMS specific equivalent</span></div></li>
|
||
|
<li><div class="src-line"><a name="a583"></a> try <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a584"></a> <span class="src-var">$expr </span>= <a href="http://www.php.net/call_user_func_array">call_user_func_array</a><span class="src-sym">(</span><span class="src-key">array</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">expression</span><span class="src-sym">, </span><span class="src-var">$name</span><span class="src-sym">)</span><span class="src-sym">, </span><span class="src-var">$args</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a585"></a> <span class="src-sym">} </span>catch<span class="src-sym">(</span><span class="src-id"><a href="../Doctrine/Doctrine_Expression_Exception.html">Doctrine_Expression_Exception</a> </span><span class="src-var">$e</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a586"></a> throw <span class="src-key">new </span><span class="src-id"><a href="../Doctrine/Doctrine_Query_Exception.html">Doctrine_Query_Exception</a></span><span class="src-sym">(</span><span class="src-str">'Unknown function ' </span>. <span class="src-var">$func </span>. <span class="src-str">'.'</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a587"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a588"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a589"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span><span class="src-var">$nestedCall</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a590"></a> <span class="src-comm">// try to find all component references</span></div></li>
|
||
|
<li><div class="src-line"><a name="a591"></a> <a href="http://www.php.net/preg_match_all">preg_match_all</a><span class="src-sym">(</span><span class="src-str">"/[a-z0-9_]+\.[a-z0-9_]+[\.[a-z0-9]+]*/i"</span><span class="src-sym">, </span><span class="src-var">$argStr</span><span class="src-sym">, </span><span class="src-var">$m</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a592"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a593"></a> <span class="src-key">if </span><span class="src-sym">(</span>isset<span class="src-sym">(</span><span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">1</span><span class="src-sym">]</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a594"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/strtoupper">strtoupper</a><span class="src-sym">(</span><span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">1</span><span class="src-sym">]</span><span class="src-sym">) </span>=== <span class="src-str">'AS'</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a595"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span>isset<span class="src-sym">(</span><span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">2</span><span class="src-sym">]</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a596"></a> throw <span class="src-key">new </span><span class="src-id"><a href="../Doctrine/Doctrine_Query_Exception.html">Doctrine_Query_Exception</a></span><span class="src-sym">(</span><span class="src-str">'Missing aggregate function alias.'</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a597"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a598"></a> <span class="src-var">$alias </span>= <span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">2</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a599"></a> <span class="src-sym">} </span><span class="src-key">else </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a600"></a> <span class="src-var">$alias </span>= <span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">1</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a601"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a602"></a> <span class="src-sym">} </span><span class="src-key">else </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a603"></a> <span class="src-var">$alias </span>= <a href="http://www.php.net/substr">substr</a><span class="src-sym">(</span><span class="src-var">$expr</span><span class="src-sym">, </span><span class="src-num">0</span><span class="src-sym">, </span><a href="http://www.php.net/strpos">strpos</a><span class="src-sym">(</span><span class="src-var">$expr</span><span class="src-sym">, </span><span class="src-str">'('</span><span class="src-sym">))</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a604"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a605"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a606"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$pendingAggregates">pendingAggregates</a><span class="src-sym">[</span><span class="src-sym">] </span>= <span class="src-key">array</span><span class="src-sym">(</span><span class="src-var">$expr</span><span class="src-sym">, </span><span class="src-var">$m</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">, </span><span class="src-var">$alias</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a607"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a608"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a609"></a> <span class="src-key">return </span><span class="src-var">$expr</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a610"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a611"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a612"></a><span class="src-doc"> * processPendingSubqueries</span></div></li>
|
||
|
<li><div class="src-line"><a name="a613"></a><span class="src-doc"> * processes pending subqueries</span></div></li>
|
||
|
<li><div class="src-line"><a name="a614"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a615"></a><span class="src-doc"> * subqueries can only be processed when the query is fully constructed</span></div></li>
|
||
|
<li><div class="src-line"><a name="a616"></a><span class="src-doc"> * since some subqueries may be correlated</span></div></li>
|
||
|
<li><div class="src-line"><a name="a617"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a618"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">void </span></div></li>
|
||
|
<li><div class="src-line"><a name="a619"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a620"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodprocessPendingSubqueries">processPendingSubqueries</a><span class="src-sym">(</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a621"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a622"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$pendingSubqueries">pendingSubqueries</a> <span class="src-key">as </span><span class="src-var">$value</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a623"></a> list<span class="src-sym">(</span><span class="src-var">$dql</span><span class="src-sym">, </span><span class="src-var">$alias</span><span class="src-sym">) </span>= <span class="src-var">$value</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a624"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a625"></a> <span class="src-var">$subquery </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodcreateSubquery">createSubquery</a><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a626"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a627"></a> <span class="src-var">$sql </span>= <span class="src-var">$subquery</span><span class="src-sym">-></span><span class="src-id">parseQuery</span><span class="src-sym">(</span><span class="src-var">$dql</span><span class="src-sym">, </span><span class="src-id">false</span><span class="src-sym">)</span><span class="src-sym">-></span><span class="src-id">getQuery</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a628"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a629"></a> <a href="../Doctrine/Doctrine_Query.html#methodreset">reset</a><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_aliasMap">_aliasMap</a><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a630"></a> <span class="src-var">$componentAlias </span>= <a href="http://www.php.net/key">key</a><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_aliasMap">_aliasMap</a><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a631"></a> <span class="src-var">$tableAlias </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodgetTableAlias">getTableAlias</a><span class="src-sym">(</span><span class="src-var">$componentAlias</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a632"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a633"></a> <span class="src-var">$sqlAlias </span>= <span class="src-var">$tableAlias </span>. <span class="src-str">'__' </span>. <a href="../Doctrine/Doctrine_Query.html#methodcount">count</a><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$aggregateMap">aggregateMap</a><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a634"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a635"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'select'</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-sym">] </span>= <span class="src-str">'(' </span>. <span class="src-var">$sql </span>. <span class="src-str">') AS ' </span>. <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$sqlAlias</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a636"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a637"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$aggregateMap">aggregateMap</a><span class="src-sym">[</span><span class="src-var">$alias</span><span class="src-sym">] </span>= <span class="src-var">$sqlAlias</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a638"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_aliasMap">_aliasMap</a><span class="src-sym">[</span><span class="src-var">$componentAlias</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-str">'agg'</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-sym">] </span>= <span class="src-var">$alias</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a639"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a640"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$pendingSubqueries">pendingSubqueries</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a641"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a642"></a> <span class="src-doc">/** </span></div></li>
|
||
|
<li><div class="src-line"><a name="a643"></a><span class="src-doc"> * processPendingAggregates</span></div></li>
|
||
|
<li><div class="src-line"><a name="a644"></a><span class="src-doc"> * processes pending aggregate values for given component alias</span></div></li>
|
||
|
<li><div class="src-line"><a name="a645"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a646"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">void </span></div></li>
|
||
|
<li><div class="src-line"><a name="a647"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a648"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodprocessPendingAggregates">processPendingAggregates</a><span class="src-sym">(</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a649"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a650"></a> <span class="src-comm">// iterate trhough all aggregates</span></div></li>
|
||
|
<li><div class="src-line"><a name="a651"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$pendingAggregates">pendingAggregates</a> <span class="src-key">as </span><span class="src-var">$aggregate</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a652"></a> list <span class="src-sym">(</span><span class="src-var">$expression</span><span class="src-sym">, </span><span class="src-var">$components</span><span class="src-sym">, </span><span class="src-var">$alias</span><span class="src-sym">) </span>= <span class="src-var">$aggregate</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a653"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a654"></a> <span class="src-var">$tableAliases </span>= <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a655"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a656"></a> <span class="src-comm">// iterate through the component references within the aggregate function</span></div></li>
|
||
|
<li><div class="src-line"><a name="a657"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty </span><span class="src-sym">(</span><span class="src-var">$components</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a658"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-var">$components </span><span class="src-key">as </span><span class="src-var">$component</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a659"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a660"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/is_numeric">is_numeric</a><span class="src-sym">(</span><span class="src-var">$component</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a661"></a> <span class="src-key">continue</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a662"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a663"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a664"></a> <span class="src-var">$e </span>= <a href="http://www.php.net/explode">explode</a><span class="src-sym">(</span><span class="src-str">'.'</span><span class="src-sym">, </span><span class="src-var">$component</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a665"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a666"></a> <span class="src-var">$field </span>= <a href="http://www.php.net/array_pop">array_pop</a><span class="src-sym">(</span><span class="src-var">$e</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a667"></a> <span class="src-var">$componentAlias </span>= <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">'.'</span><span class="src-sym">, </span><span class="src-var">$e</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a668"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a669"></a> <span class="src-comm">// check the existence of the component alias</span></div></li>
|
||
|
<li><div class="src-line"><a name="a670"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span>isset<span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_aliasMap">_aliasMap</a><span class="src-sym">[</span><span class="src-var">$componentAlias</span><span class="src-sym">]</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a671"></a> throw <span class="src-key">new </span><span class="src-id"><a href="../Doctrine/Doctrine_Query_Exception.html">Doctrine_Query_Exception</a></span><span class="src-sym">(</span><span class="src-str">'Unknown component alias ' </span>. <span class="src-var">$componentAlias</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a672"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a673"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a674"></a> <span class="src-var">$table </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_aliasMap">_aliasMap</a><span class="src-sym">[</span><span class="src-var">$componentAlias</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-str">'table'</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a675"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a676"></a> <span class="src-var">$field </span>= <span class="src-var">$table</span><span class="src-sym">-></span><span class="src-id">getColumnName</span><span class="src-sym">(</span><span class="src-var">$field</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a677"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a678"></a> <span class="src-comm">// check column existence</span></div></li>
|
||
|
<li><div class="src-line"><a name="a679"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span><span class="src-var">$table</span><span class="src-sym">-></span><span class="src-id">hasColumn</span><span class="src-sym">(</span><span class="src-var">$field</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a680"></a> throw <span class="src-key">new </span><span class="src-id"><a href="../Doctrine/Doctrine_Query_Exception.html">Doctrine_Query_Exception</a></span><span class="src-sym">(</span><span class="src-str">'Unknown column ' </span>. <span class="src-var">$field</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a681"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a682"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a683"></a> <span class="src-var">$tableAlias </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodgetTableAlias">getTableAlias</a><span class="src-sym">(</span><span class="src-var">$componentAlias</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a684"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a685"></a> <span class="src-var">$tableAliases</span><span class="src-sym">[</span><span class="src-var">$tableAlias</span><span class="src-sym">] </span>= <span class="src-id">true</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a686"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a687"></a> <span class="src-comm">// build sql expression</span></div></li>
|
||
|
<li><div class="src-line"><a name="a688"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a689"></a> <span class="src-var">$identifier </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$tableAlias </span>. <span class="src-str">'.' </span>. <span class="src-var">$field</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a690"></a> <span class="src-var">$expression </span>= <a href="http://www.php.net/str_replace">str_replace</a><span class="src-sym">(</span><span class="src-var">$component</span><span class="src-sym">, </span><span class="src-var">$identifier</span><span class="src-sym">, </span><span class="src-var">$expression</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a691"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a692"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a693"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a694"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="../Doctrine/Doctrine_Query.html#methodcount">count</a><span class="src-sym">(</span><span class="src-var">$tableAliases</span><span class="src-sym">) </span>!== <span class="src-num">1</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a695"></a> <span class="src-var">$componentAlias </span>= <a href="../Doctrine/Doctrine_Query.html#methodreset">reset</a><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><span class="src-var">tableAliases</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a696"></a> <span class="src-var">$tableAlias </span>= <a href="http://www.php.net/key">key</a><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><span class="src-var">tableAliases</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a697"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a698"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a699"></a> <span class="src-var">$index </span>= <a href="../Doctrine/Doctrine_Query.html#methodcount">count</a><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$aggregateMap">aggregateMap</a><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a700"></a> <span class="src-var">$sqlAlias </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$tableAlias </span>. <span class="src-str">'__' </span>. <span class="src-var">$index</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a701"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a702"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'select'</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-sym">] </span>= <span class="src-var">$expression </span>. <span class="src-str">' AS ' </span>. <span class="src-var">$sqlAlias</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a703"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a704"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$aggregateMap">aggregateMap</a><span class="src-sym">[</span><span class="src-var">$alias</span><span class="src-sym">] </span>= <span class="src-var">$sqlAlias</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a705"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_expressionMap">_expressionMap</a><span class="src-sym">[</span><span class="src-var">$alias</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">] </span>= <span class="src-var">$expression</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a706"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a707"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_aliasMap">_aliasMap</a><span class="src-sym">[</span><span class="src-var">$componentAlias</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-str">'agg'</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-var">$index</span><span class="src-sym">] </span>= <span class="src-var">$alias</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a708"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a709"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-var">neededTables</span><span class="src-sym">[</span><span class="src-sym">] </span>= <span class="src-var">$tableAlias</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a710"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a711"></a> <span class="src-comm">// reset the state</span></div></li>
|
||
|
<li><div class="src-line"><a name="a712"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$pendingAggregates">pendingAggregates</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a713"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a714"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a715"></a><span class="src-doc"> * getQueryBase</span></div></li>
|
||
|
<li><div class="src-line"><a name="a716"></a><span class="src-doc"> * returns the base of the generated sql query</span></div></li>
|
||
|
<li><div class="src-line"><a name="a717"></a><span class="src-doc"> * On mysql driver special strategy has to be used for DELETE statements</span></div></li>
|
||
|
<li><div class="src-line"><a name="a718"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a719"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">string </span><span class="src-doc"> the base of the generated sql query</span></div></li>
|
||
|
<li><div class="src-line"><a name="a720"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a721"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodgetQueryBase">getQueryBase</a><span class="src-sym">(</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a722"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a723"></a> <span class="src-key">switch </span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$type">type</a><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a724"></a> <span class="src-key">case </span><span class="src-id">self</span><span class="src-sym">::</span><span class="src-id">DELETE</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a725"></a> <span class="src-var">$q </span>= <span class="src-str">'DELETE FROM '</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a726"></a> <span class="src-key">break</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a727"></a> <span class="src-key">case </span><span class="src-id">self</span><span class="src-sym">::</span><span class="src-id">UPDATE</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a728"></a> <span class="src-var">$q </span>= <span class="src-str">'UPDATE '</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a729"></a> <span class="src-key">break</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a730"></a> <span class="src-key">case </span><span class="src-id">self</span><span class="src-sym">::</span><span class="src-id">SELECT</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a731"></a> <span class="src-var">$distinct </span>= <span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'distinct'</span><span class="src-sym">]</span><span class="src-sym">) </span>? <span class="src-str">'DISTINCT ' </span>: <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a732"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a733"></a> <span class="src-var">$q </span>= <span class="src-str">'SELECT ' </span>. <span class="src-var">$distinct </span>. <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">', '</span><span class="src-sym">, </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'select'</span><span class="src-sym">]</span><span class="src-sym">) </span>. <span class="src-str">' FROM '</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a734"></a> <span class="src-key">break</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a735"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a736"></a> <span class="src-key">return </span><span class="src-var">$q</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a737"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a738"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a739"></a><span class="src-doc"> * buildFromPart</span></div></li>
|
||
|
<li><div class="src-line"><a name="a740"></a><span class="src-doc"> * builds the from part of the query and returns it</span></div></li>
|
||
|
<li><div class="src-line"><a name="a741"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a742"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">string </span><span class="src-doc"> the query sql from part</span></div></li>
|
||
|
<li><div class="src-line"><a name="a743"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a744"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodbuildFromPart">buildFromPart</a><span class="src-sym">(</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a745"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a746"></a> <span class="src-var">$q </span>= <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a747"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'from'</span><span class="src-sym">] </span><span class="src-key">as </span><span class="src-var">$k </span>=> <span class="src-var">$part</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a748"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$k </span>=== <span class="src-num">0</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a749"></a> <span class="src-var">$q </span>.= <span class="src-var">$part</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a750"></a> <span class="src-key">continue</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a751"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a752"></a> <span class="src-comm">// preserve LEFT JOINs only if needed</span></div></li>
|
||
|
<li><div class="src-line"><a name="a753"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a754"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/substr">substr</a><span class="src-sym">(</span><span class="src-var">$part</span><span class="src-sym">, </span><span class="src-num">0</span><span class="src-sym">, </span><span class="src-num">9</span><span class="src-sym">) </span>=== <span class="src-str">'LEFT JOIN'</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a755"></a> <span class="src-var">$e </span>= <a href="http://www.php.net/explode">explode</a><span class="src-sym">(</span><span class="src-str">' '</span><span class="src-sym">, </span><span class="src-var">$part</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a756"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a757"></a> <span class="src-var">$aliases </span>= <a href="http://www.php.net/array_merge">array_merge</a><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$subqueryAliases">subqueryAliases</a><span class="src-sym">,</span></div></li>
|
||
|
<li><div class="src-line"><a name="a758"></a> <a href="http://www.php.net/array_keys">array_keys</a><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><span class="src-var">neededTables</span><span class="src-sym">))</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a759"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a760"></a> <span class="src-key">if</span><span class="src-sym">( </span><span class="src-sym">! </span><a href="http://www.php.net/in_array">in_array</a><span class="src-sym">(</span><span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">3</span><span class="src-sym">]</span><span class="src-sym">, </span><span class="src-var">$aliases</span><span class="src-sym">) </span>&&</div></li>
|
||
|
<li><div class="src-line"><a name="a761"></a> <span class="src-sym">! </span><a href="http://www.php.net/in_array">in_array</a><span class="src-sym">(</span><span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">2</span><span class="src-sym">]</span><span class="src-sym">, </span><span class="src-var">$aliases</span><span class="src-sym">) </span>&&</div></li>
|
||
|
<li><div class="src-line"><a name="a762"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a763"></a> <span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$pendingFields">pendingFields</a><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a764"></a> <span class="src-key">continue</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a765"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a766"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a767"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a768"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a769"></a> <span class="src-key">if </span><span class="src-sym">(</span>isset<span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_pendingJoinConditions">_pendingJoinConditions</a><span class="src-sym">[</span><span class="src-var">$k</span><span class="src-sym">]</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a770"></a> <span class="src-var">$parser </span>= <span class="src-key">new </span><span class="src-id"><a href="../Doctrine/Doctrine_Query_JoinCondition.html">Doctrine_Query_JoinCondition</a></span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a771"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a772"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/strpos">strpos</a><span class="src-sym">(</span><span class="src-var">$part</span><span class="src-sym">, </span><span class="src-str">' ON '</span><span class="src-sym">) </span>!== <span class="src-id">false</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a773"></a> <span class="src-var">$part </span>.= <span class="src-str">' AND '</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a774"></a> <span class="src-sym">} </span><span class="src-key">else </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a775"></a> <span class="src-var">$part </span>.= <span class="src-str">' ON '</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a776"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a777"></a> <span class="src-var">$part </span>.= <span class="src-var">$parser</span><span class="src-sym">-></span><span class="src-id">parse</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_pendingJoinConditions">_pendingJoinConditions</a><span class="src-sym">[</span><span class="src-var">$k</span><span class="src-sym">]</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a778"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a779"></a> unset<span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_pendingJoinConditions">_pendingJoinConditions</a><span class="src-sym">[</span><span class="src-var">$k</span><span class="src-sym">]</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a780"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a781"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a782"></a> <span class="src-var">$q </span>.= <span class="src-str">' ' </span>. <span class="src-var">$part</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a783"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a784"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'from'</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-var">$k</span><span class="src-sym">] </span>= <span class="src-var">$part</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a785"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a786"></a> <span class="src-key">return </span><span class="src-var">$q</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a787"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a788"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a789"></a><span class="src-doc"> * preQuery</span></div></li>
|
||
|
<li><div class="src-line"><a name="a790"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a791"></a><span class="src-doc"> * Empty template method to provide Query subclasses with the possibility</span></div></li>
|
||
|
<li><div class="src-line"><a name="a792"></a><span class="src-doc"> * to hook into the query building procedure, doing any custom / specialized</span></div></li>
|
||
|
<li><div class="src-line"><a name="a793"></a><span class="src-doc"> * query building procedures that are neccessary.</span></div></li>
|
||
|
<li><div class="src-line"><a name="a794"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a795"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">void </span></div></li>
|
||
|
<li><div class="src-line"><a name="a796"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a797"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodpreQuery">preQuery</a><span class="src-sym">(</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a798"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a799"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a800"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a801"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a802"></a><span class="src-doc"> * postQuery</span></div></li>
|
||
|
<li><div class="src-line"><a name="a803"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a804"></a><span class="src-doc"> * Empty template method to provide Query subclasses with the possibility</span></div></li>
|
||
|
<li><div class="src-line"><a name="a805"></a><span class="src-doc"> * to hook into the query building procedure, doing any custom / specialized</span></div></li>
|
||
|
<li><div class="src-line"><a name="a806"></a><span class="src-doc"> * post query procedures (for example logging) that are neccessary.</span></div></li>
|
||
|
<li><div class="src-line"><a name="a807"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a808"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">void </span></div></li>
|
||
|
<li><div class="src-line"><a name="a809"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a810"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodpostQuery">postQuery</a><span class="src-sym">(</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a811"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a812"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a813"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a814"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a815"></a><span class="src-doc"> * builds the sql query from the given parameters and applies things such as</span></div></li>
|
||
|
<li><div class="src-line"><a name="a816"></a><span class="src-doc"> * column aggregation inheritance and limit subqueries if needed</span></div></li>
|
||
|
<li><div class="src-line"><a name="a817"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a818"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">array </span><span class="src-doc-var">$params </span><span class="src-doc"> an array of prepared statement params (needed only in mysql driver</span></div></li>
|
||
|
<li><div class="src-line"><a name="a819"></a><span class="src-doc"> * when limit subquery algorithm is used)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a820"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">string </span><span class="src-doc"> the built sql query</span></div></li>
|
||
|
<li><div class="src-line"><a name="a821"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a822"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodgetQuery">getQuery</a><span class="src-sym">(</span><span class="src-var">$params </span>= <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">))</span></div></li>
|
||
|
<li><div class="src-line"><a name="a823"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a824"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_state">_state</a> !== <span class="src-id">self</span><span class="src-sym">::</span><span class="src-id">STATE_DIRTY</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a825"></a> <span class="src-key">return </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_sql">_sql</a><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a826"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a827"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a828"></a> <span class="src-var">$parts </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a829"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a830"></a> <span class="src-comm">// reset the state</span></div></li>
|
||
|
<li><div class="src-line"><a name="a831"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodisSubquery">isSubquery</a><span class="src-sym">(</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a832"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_aliasMap">_aliasMap</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a833"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$pendingAggregates">pendingAggregates</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a834"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$aggregateMap">aggregateMap</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a835"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a836"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodreset">reset</a><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">; </span></div></li>
|
||
|
<li><div class="src-line"><a name="a837"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a838"></a> <span class="src-comm">// parse the DQL parts</span></div></li>
|
||
|
<li><div class="src-line"><a name="a839"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a> <span class="src-key">as </span><span class="src-var">$queryPartName </span>=> <span class="src-var">$queryParts</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a840"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a841"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodremoveQueryPart">removeQueryPart</a><span class="src-sym">(</span><span class="src-var">$queryPartName</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a842"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a843"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/is_array">is_array</a><span class="src-sym">(</span><span class="src-var">$queryParts</span><span class="src-sym">) </span>&& <span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$queryParts</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a844"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a845"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-var">$queryParts </span><span class="src-key">as </span><span class="src-var">$queryPart</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a846"></a> <span class="src-var">$parser </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodgetParser">getParser</a><span class="src-sym">(</span><span class="src-var">$queryPartName</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a847"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a848"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a849"></a> <span class="src-var">$sql </span>= <span class="src-var">$parser</span><span class="src-sym">-></span><span class="src-id">parse</span><span class="src-sym">(</span><span class="src-var">$queryPart</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a850"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a851"></a> <span class="src-key">if </span><span class="src-sym">(</span>isset<span class="src-sym">(</span><span class="src-var">$sql</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a852"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$queryPartName </span>== <span class="src-str">'limit' </span>||</div></li>
|
||
|
<li><div class="src-line"><a name="a853"></a> <span class="src-var">$queryPartName </span>== <span class="src-str">'offset'</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a854"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a855"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodsetQueryPart">setQueryPart</a><span class="src-sym">(</span><span class="src-var">$queryPartName</span><span class="src-sym">, </span><span class="src-var">$sql</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a856"></a> <span class="src-sym">} </span><span class="src-key">else </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a857"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodaddQueryPart">addQueryPart</a><span class="src-sym">(</span><span class="src-var">$queryPartName</span><span class="src-sym">, </span><span class="src-var">$sql</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a858"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a859"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a860"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a861"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a862"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a863"></a> <span class="src-var">$params </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodconvertEnums">convertEnums</a><span class="src-sym">(</span><span class="src-var">$params</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a864"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a865"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_state">_state</a> = <span class="src-id">self</span><span class="src-sym">::</span><span class="src-id">STATE_DIRECT</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a866"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a867"></a> <span class="src-comm">// invoke the preQuery hook</span></div></li>
|
||
|
<li><div class="src-line"><a name="a868"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodpreQuery">preQuery</a><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">; </span></div></li>
|
||
|
<li><div class="src-line"><a name="a869"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_state">_state</a> = <span class="src-id">self</span><span class="src-sym">::</span><span class="src-id">STATE_CLEAN</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a870"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a871"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a> = <span class="src-var">$parts</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a872"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a873"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'from'</span><span class="src-sym">]</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a874"></a> <span class="src-key">return </span><span class="src-id">false</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a875"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a876"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a877"></a> <span class="src-var">$needsSubQuery </span>= <span class="src-id">false</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a878"></a> <span class="src-var">$subquery </span>= <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a879"></a> <span class="src-var">$map </span>= <a href="../Doctrine/Doctrine_Query.html#methodreset">reset</a><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_aliasMap">_aliasMap</a><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a880"></a> <span class="src-var">$table </span>= <span class="src-var">$map</span><span class="src-sym">[</span><span class="src-str">'table'</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a881"></a> <span class="src-var">$rootAlias </span>= <a href="http://www.php.net/key">key</a><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_aliasMap">_aliasMap</a><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a882"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a883"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'limit'</span><span class="src-sym">]</span><span class="src-sym">) </span>&& <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$needsSubquery">needsSubquery</a> && <span class="src-var">$table</span><span class="src-sym">-></span><span class="src-id">getAttribute</span><span class="src-sym">(</span><span class="src-id"><a href="../Doctrine/Doctrine.html">Doctrine</a></span><span class="src-sym">::</span><span class="src-id">ATTR_QUERY_LIMIT</span><span class="src-sym">) </span>== <span class="src-id"><a href="../Doctrine/Doctrine.html">Doctrine</a></span><span class="src-sym">::</span><span class="src-id">LIMIT_RECORDS</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a884"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$isLimitSubqueryUsed">isLimitSubqueryUsed</a> = <span class="src-id">true</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a885"></a> <span class="src-var">$needsSubQuery </span>= <span class="src-id">true</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a886"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a887"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a888"></a> <span class="src-comm">// process all pending SELECT part subqueries</span></div></li>
|
||
|
<li><div class="src-line"><a name="a889"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodprocessPendingSubqueries">processPendingSubqueries</a><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a890"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodprocessPendingAggregates">processPendingAggregates</a><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a891"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a892"></a> <span class="src-comm">// build the basic query</span></div></li>
|
||
|
<li><div class="src-line"><a name="a893"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a894"></a> <span class="src-var">$q </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodgetQueryBase">getQueryBase</a><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a895"></a> <span class="src-var">$q </span>.= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodbuildFromPart">buildFromPart</a><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a896"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a897"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'set'</span><span class="src-sym">]</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a898"></a> <span class="src-var">$q </span>.= <span class="src-str">' SET ' </span>. <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">', '</span><span class="src-sym">, </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'set'</span><span class="src-sym">]</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a899"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a900"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a901"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a902"></a> <span class="src-var">$string </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodapplyInheritance">applyInheritance</a><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a903"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a904"></a> <span class="src-comm">// apply inheritance to WHERE part</span></div></li>
|
||
|
<li><div class="src-line"><a name="a905"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$string</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a906"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'where'</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-sym">] </span>= <span class="src-str">'(' </span>. <span class="src-var">$string </span>. <span class="src-str">')'</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a907"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a908"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a909"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a910"></a> <span class="src-var">$modifyLimit </span>= <span class="src-id">true</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a911"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'limit'</span><span class="src-sym">]</span><span class="src-sym">) </span>|| <span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'offset'</span><span class="src-sym">]</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a912"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a913"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$needsSubQuery</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a914"></a> <span class="src-var">$subquery </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodgetLimitSubquery">getLimitSubquery</a><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a915"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a916"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a917"></a> <span class="src-key">switch </span><span class="src-sym">(</span><a href="http://www.php.net/strtolower">strtolower</a><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">getName</span><span class="src-sym">(</span><span class="src-sym">))) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a918"></a> <span class="src-key">case </span><span class="src-str">'mysql'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a919"></a> <span class="src-comm">// mysql doesn't support LIMIT in subqueries</span></div></li>
|
||
|
<li><div class="src-line"><a name="a920"></a> <span class="src-var">$list </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">execute</span><span class="src-sym">(</span><span class="src-var">$subquery</span><span class="src-sym">, </span><span class="src-var">$params</span><span class="src-sym">)</span><span class="src-sym">-></span><span class="src-id">fetchAll</span><span class="src-sym">(</span><span class="src-id"><a href="../Doctrine/Doctrine.html">Doctrine</a></span><span class="src-sym">::</span><span class="src-id">FETCH_COLUMN</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a921"></a> <span class="src-var">$subquery </span>= <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">', '</span><span class="src-sym">, </span><a href="http://www.php.net/array_map">array_map</a><span class="src-sym">(</span><span class="src-key">array</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">, </span><span class="src-str">'quote'</span><span class="src-sym">)</span><span class="src-sym">, </span><span class="src-var">$list</span><span class="src-sym">))</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a922"></a> <span class="src-key">break</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a923"></a> <span class="src-key">case </span><span class="src-str">'pgsql'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a924"></a> <span class="src-comm">// pgsql needs special nested LIMIT subquery</span></div></li>
|
||
|
<li><div class="src-line"><a name="a925"></a> <span class="src-var">$subquery </span>= <span class="src-str">'SELECT doctrine_subquery_alias.' </span>. <span class="src-var">$table</span><span class="src-sym">-></span><span class="src-id">getIdentifier</span><span class="src-sym">(</span><span class="src-sym">)</span>. <span class="src-str">' FROM (' </span>. <span class="src-var">$subquery </span>. <span class="src-str">') AS doctrine_subquery_alias'</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a926"></a> <span class="src-key">break</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a927"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a928"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a929"></a> <span class="src-var">$field </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodgetTableAlias">getTableAlias</a><span class="src-sym">(</span><span class="src-var">$rootAlias</span><span class="src-sym">) </span>. <span class="src-str">'.' </span>. <span class="src-var">$table</span><span class="src-sym">-></span><span class="src-id">getIdentifier</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a930"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a931"></a> <span class="src-comm">// only append the subquery if it actually contains something</span></div></li>
|
||
|
<li><div class="src-line"><a name="a932"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$subquery </span>!== <span class="src-str">''</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a933"></a> <a href="http://www.php.net/array_unshift">array_unshift</a><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'where'</span><span class="src-sym">]</span><span class="src-sym">, </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$field</span><span class="src-sym">) </span>. <span class="src-str">' IN (' </span>. <span class="src-var">$subquery </span>. <span class="src-str">')'</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a934"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a935"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a936"></a> <span class="src-var">$modifyLimit </span>= <span class="src-id">false</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a937"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a938"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a939"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a940"></a> <span class="src-var">$q </span>.= <span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'where'</span><span class="src-sym">]</span><span class="src-sym">))</span>? <span class="src-str">' WHERE ' </span>. <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">' AND '</span><span class="src-sym">, </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'where'</span><span class="src-sym">]</span><span class="src-sym">) </span>: <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a941"></a> <span class="src-var">$q </span>.= <span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'groupby'</span><span class="src-sym">]</span><span class="src-sym">))</span>? <span class="src-str">' GROUP BY ' </span>. <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">', '</span><span class="src-sym">, </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'groupby'</span><span class="src-sym">]</span><span class="src-sym">) </span>: <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a942"></a> <span class="src-var">$q </span>.= <span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'having'</span><span class="src-sym">]</span><span class="src-sym">))</span>? <span class="src-str">' HAVING ' </span>. <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">' AND '</span><span class="src-sym">, </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'having'</span><span class="src-sym">]</span><span class="src-sym">)</span>: <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a943"></a> <span class="src-var">$q </span>.= <span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'orderby'</span><span class="src-sym">]</span><span class="src-sym">))</span>? <span class="src-str">' ORDER BY ' </span>. <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">', '</span><span class="src-sym">, </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'orderby'</span><span class="src-sym">]</span><span class="src-sym">) </span>: <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a944"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a945"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$modifyLimit</span><span class="src-sym">) </span><span class="src-sym">{ </span></div></li>
|
||
|
<li><div class="src-line"><a name="a946"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a947"></a> <span class="src-var">$q </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">modifyLimitQuery</span><span class="src-sym">(</span><span class="src-var">$q</span><span class="src-sym">, </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'limit'</span><span class="src-sym">]</span><span class="src-sym">, </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'offset'</span><span class="src-sym">]</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a948"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a949"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a950"></a> <span class="src-comm">// return to the previous state</span></div></li>
|
||
|
<li><div class="src-line"><a name="a951"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$string</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a952"></a> <a href="http://www.php.net/array_pop">array_pop</a><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'where'</span><span class="src-sym">]</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a953"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a954"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$needsSubQuery</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a955"></a> <a href="http://www.php.net/array_shift">array_shift</a><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'where'</span><span class="src-sym">]</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a956"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a957"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_sql">_sql</a> = <span class="src-var">$q</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a958"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a959"></a> <span class="src-key">return </span><span class="src-var">$q</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a960"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a961"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a962"></a><span class="src-doc"> * getLimitSubquery</span></div></li>
|
||
|
<li><div class="src-line"><a name="a963"></a><span class="src-doc"> * this is method is used by the record limit algorithm</span></div></li>
|
||
|
<li><div class="src-line"><a name="a964"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a965"></a><span class="src-doc"> * when fetching one-to-many, many-to-many associated data with LIMIT clause</span></div></li>
|
||
|
<li><div class="src-line"><a name="a966"></a><span class="src-doc"> * an additional subquery is needed for limiting the number of returned records instead</span></div></li>
|
||
|
<li><div class="src-line"><a name="a967"></a><span class="src-doc"> * of limiting the number of sql result set rows</span></div></li>
|
||
|
<li><div class="src-line"><a name="a968"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a969"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">string </span><span class="src-doc"> the limit subquery</span></div></li>
|
||
|
<li><div class="src-line"><a name="a970"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a971"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodgetLimitSubquery">getLimitSubquery</a><span class="src-sym">(</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a972"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a973"></a> <span class="src-var">$map </span>= <a href="../Doctrine/Doctrine_Query.html#methodreset">reset</a><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_aliasMap">_aliasMap</a><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a974"></a> <span class="src-var">$table </span>= <span class="src-var">$map</span><span class="src-sym">[</span><span class="src-str">'table'</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a975"></a> <span class="src-var">$componentAlias </span>= <a href="http://www.php.net/key">key</a><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_aliasMap">_aliasMap</a><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a976"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a977"></a> <span class="src-comm">// get short alias</span></div></li>
|
||
|
<li><div class="src-line"><a name="a978"></a> <span class="src-var">$alias </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodgetTableAlias">getTableAlias</a><span class="src-sym">(</span><span class="src-var">$componentAlias</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a979"></a> <span class="src-var">$primaryKey </span>= <span class="src-var">$alias </span>. <span class="src-str">'.' </span>. <span class="src-var">$table</span><span class="src-sym">-></span><span class="src-id">getIdentifier</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a980"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a981"></a> <span class="src-comm">// initialize the base of the subquery</span></div></li>
|
||
|
<li><div class="src-line"><a name="a982"></a> <span class="src-var">$subquery </span>= <span class="src-str">'SELECT DISTINCT ' </span>. <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$primaryKey</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a983"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a984"></a> <span class="src-var">$driverName </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">getAttribute</span><span class="src-sym">(</span><span class="src-id"><a href="../Doctrine/Doctrine.html">Doctrine</a></span><span class="src-sym">::</span><span class="src-id">ATTR_DRIVER_NAME</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a985"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a986"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a987"></a> <span class="src-comm">// pgsql needs the order by fields to be preserved in select clause</span></div></li>
|
||
|
<li><div class="src-line"><a name="a988"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$driverName </span>== <span class="src-str">'pgsql'</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a989"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'orderby'</span><span class="src-sym">] </span><span class="src-key">as </span><span class="src-var">$part</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a990"></a> <span class="src-var">$part </span>= <a href="http://www.php.net/trim">trim</a><span class="src-sym">(</span><span class="src-var">$part</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a991"></a> <span class="src-var">$e </span>= <span class="src-id"><a href="../Doctrine/Doctrine_Tokenizer.html">Doctrine_Tokenizer</a></span><span class="src-sym">::</span><a href="../Doctrine/Doctrine_Tokenizer.html#methodbracketExplode">bracketExplode</a><span class="src-sym">(</span><span class="src-var">$part</span><span class="src-sym">, </span><span class="src-str">' '</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a992"></a> <span class="src-var">$part </span>= <a href="http://www.php.net/trim">trim</a><span class="src-sym">(</span><span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a993"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a994"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/strpos">strpos</a><span class="src-sym">(</span><span class="src-var">$part</span><span class="src-sym">, </span><span class="src-str">'.'</span><span class="src-sym">) </span>=== <span class="src-id">false</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a995"></a> <span class="src-key">continue</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a996"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a997"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a998"></a> <span class="src-comm">// don't add functions</span></div></li>
|
||
|
<li><div class="src-line"><a name="a999"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/strpos">strpos</a><span class="src-sym">(</span><span class="src-var">$part</span><span class="src-sym">, </span><span class="src-str">'('</span><span class="src-sym">) </span>!== <span class="src-id">false</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1000"></a> <span class="src-key">continue</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1001"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1002"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1003"></a> <span class="src-comm">// don't add primarykey column (its already in the select clause)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1004"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$part </span>!== <span class="src-var">$primaryKey</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1005"></a> <span class="src-var">$subquery </span>.= <span class="src-str">', ' </span>. <span class="src-var">$part</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1006"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1007"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1008"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1009"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1010"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$driverName </span>== <span class="src-str">'mysql' </span>|| <span class="src-var">$driverName </span>== <span class="src-str">'pgsql'</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1011"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_expressionMap">_expressionMap</a> <span class="src-key">as </span><span class="src-var">$dqlAlias </span>=> <span class="src-var">$expr</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1012"></a> <span class="src-key">if </span><span class="src-sym">(</span>isset<span class="src-sym">(</span><span class="src-var">$expr</span><span class="src-sym">[</span><span class="src-num">1</span><span class="src-sym">]</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1013"></a> <span class="src-var">$subquery </span>.= <span class="src-str">', ' </span>. <span class="src-var">$expr</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">] </span>. <span class="src-str">' AS ' </span>. <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$aggregateMap">aggregateMap</a><span class="src-sym">[</span><span class="src-var">$dqlAlias</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1014"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1015"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1016"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1017"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1018"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1019"></a> <span class="src-var">$subquery </span>.= <span class="src-str">' FROM'</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1020"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1021"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1022"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'from'</span><span class="src-sym">] </span><span class="src-key">as </span><span class="src-var">$part</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1023"></a> <span class="src-comm">// preserve LEFT JOINs only if needed</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1024"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/substr">substr</a><span class="src-sym">(</span><span class="src-var">$part</span><span class="src-sym">, </span><span class="src-num">0</span><span class="src-sym">, </span><span class="src-num">9</span><span class="src-sym">) </span>=== <span class="src-str">'LEFT JOIN'</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1025"></a> <span class="src-var">$e </span>= <a href="http://www.php.net/explode">explode</a><span class="src-sym">(</span><span class="src-str">' '</span><span class="src-sym">, </span><span class="src-var">$part</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1026"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1027"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'orderby'</span><span class="src-sym">]</span><span class="src-sym">) </span>&& <span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'where'</span><span class="src-sym">]</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1028"></a> <span class="src-key">continue</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1029"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1030"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1031"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1032"></a> <span class="src-var">$subquery </span>.= <span class="src-str">' ' </span>. <span class="src-var">$part</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1033"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1034"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1035"></a> <span class="src-comm">// all conditions must be preserved in subquery</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1036"></a> <span class="src-var">$subquery </span>.= <span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'where'</span><span class="src-sym">]</span><span class="src-sym">))</span>? <span class="src-str">' WHERE ' </span>. <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">' AND '</span><span class="src-sym">, </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'where'</span><span class="src-sym">]</span><span class="src-sym">) </span>: <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1037"></a> <span class="src-var">$subquery </span>.= <span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'groupby'</span><span class="src-sym">]</span><span class="src-sym">))</span>? <span class="src-str">' GROUP BY ' </span>. <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">', '</span><span class="src-sym">, </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'groupby'</span><span class="src-sym">]</span><span class="src-sym">) </span>: <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1038"></a> <span class="src-var">$subquery </span>.= <span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'having'</span><span class="src-sym">]</span><span class="src-sym">))</span>? <span class="src-str">' HAVING ' </span>. <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">' AND '</span><span class="src-sym">, </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'having'</span><span class="src-sym">]</span><span class="src-sym">) </span>: <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1039"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1040"></a> <span class="src-var">$subquery </span>.= <span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'orderby'</span><span class="src-sym">]</span><span class="src-sym">))</span>? <span class="src-str">' ORDER BY ' </span>. <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">', '</span><span class="src-sym">, </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'orderby'</span><span class="src-sym">]</span><span class="src-sym">) </span>: <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1041"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1042"></a> <span class="src-comm">// add driver specific limit clause</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1043"></a> <span class="src-var">$subquery </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">modifyLimitQuery</span><span class="src-sym">(</span><span class="src-var">$subquery</span><span class="src-sym">, </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'limit'</span><span class="src-sym">]</span><span class="src-sym">, </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'offset'</span><span class="src-sym">]</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1044"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1045"></a> <span class="src-var">$parts </span>= <span class="src-id"><a href="../Doctrine/Doctrine_Tokenizer.html">Doctrine_Tokenizer</a></span><span class="src-sym">::</span><a href="../Doctrine/Doctrine_Tokenizer.html#methodquoteExplode">quoteExplode</a><span class="src-sym">(</span><span class="src-var">$subquery</span><span class="src-sym">, </span><span class="src-str">' '</span><span class="src-sym">, </span><span class="src-str">"'"</span><span class="src-sym">, </span><span class="src-str">"'"</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1046"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1047"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-var">$parts </span><span class="src-key">as </span><span class="src-var">$k </span>=> <span class="src-var">$part</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1048"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/strpos">strpos</a><span class="src-sym">(</span><span class="src-var">$part</span><span class="src-sym">, </span><span class="src-str">' '</span><span class="src-sym">) </span>!== <span class="src-id">false</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1049"></a> <span class="src-key">continue</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1050"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1051"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1052"></a> <span class="src-var">$part </span>= <a href="http://www.php.net/trim">trim</a><span class="src-sym">(</span><span class="src-var">$part</span><span class="src-sym">, </span><span class="src-str">"\"'`"</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1053"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1054"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodhasTableAlias">hasTableAlias</a><span class="src-sym">(</span><span class="src-var">$part</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1055"></a> <span class="src-var">$parts</span><span class="src-sym">[</span><span class="src-var">$k</span><span class="src-sym">] </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodgenerateNewTableAlias">generateNewTableAlias</a><span class="src-sym">(</span><span class="src-var">$part</span><span class="src-sym">))</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1056"></a> <span class="src-key">continue</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1057"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1058"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1059"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/strpos">strpos</a><span class="src-sym">(</span><span class="src-var">$part</span><span class="src-sym">, </span><span class="src-str">'.'</span><span class="src-sym">) </span>=== <span class="src-id">false</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1060"></a> <span class="src-key">continue</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1061"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1062"></a> <a href="http://www.php.net/preg_match_all">preg_match_all</a><span class="src-sym">(</span><span class="src-str">"/[a-zA-Z0-9_]+\.[a-z0-9_]+/i"</span><span class="src-sym">, </span><span class="src-var">$part</span><span class="src-sym">, </span><span class="src-var">$m</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1063"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1064"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-var">$m</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">] </span><span class="src-key">as </span><span class="src-var">$match</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1065"></a> <span class="src-var">$e </span>= <a href="http://www.php.net/explode">explode</a><span class="src-sym">(</span><span class="src-str">'.'</span><span class="src-sym">, </span><span class="src-var">$match</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1066"></a> <span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">] </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodgenerateNewTableAlias">generateNewTableAlias</a><span class="src-sym">(</span><span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1067"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1068"></a> <span class="src-var">$parts</span><span class="src-sym">[</span><span class="src-var">$k</span><span class="src-sym">] </span>= <a href="http://www.php.net/str_replace">str_replace</a><span class="src-sym">(</span><span class="src-var">$match</span><span class="src-sym">, </span><a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">'.'</span><span class="src-sym">, </span><span class="src-var">$e</span><span class="src-sym">)</span><span class="src-sym">, </span><span class="src-var">$parts</span><span class="src-sym">[</span><span class="src-var">$k</span><span class="src-sym">]</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1069"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1070"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1071"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1072"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$driverName </span>== <span class="src-str">'mysql' </span>|| <span class="src-var">$driverName </span>== <span class="src-str">'pgsql'</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1073"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-var">$parts </span><span class="src-key">as </span><span class="src-var">$k </span>=> <span class="src-var">$part</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1074"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/strpos">strpos</a><span class="src-sym">(</span><span class="src-var">$part</span><span class="src-sym">, </span><span class="src-str">"'"</span><span class="src-sym">) </span>!== <span class="src-id">false</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1075"></a> <span class="src-key">continue</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1076"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1077"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/strpos">strpos</a><span class="src-sym">(</span><span class="src-var">$part</span><span class="src-sym">, </span><span class="src-str">'__'</span><span class="src-sym">) </span>== <span class="src-id">false</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1078"></a> <span class="src-key">continue</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1079"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1080"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1081"></a> <a href="http://www.php.net/preg_match_all">preg_match_all</a><span class="src-sym">(</span><span class="src-str">"/[a-zA-Z0-9_]+\_\_[a-z0-9_]+/i"</span><span class="src-sym">, </span><span class="src-var">$part</span><span class="src-sym">, </span><span class="src-var">$m</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1082"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1083"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-var">$m</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">] </span><span class="src-key">as </span><span class="src-var">$match</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1084"></a> <span class="src-var">$e </span>= <a href="http://www.php.net/explode">explode</a><span class="src-sym">(</span><span class="src-str">'__'</span><span class="src-sym">, </span><span class="src-var">$match</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1085"></a> <span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">] </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodgenerateNewTableAlias">generateNewTableAlias</a><span class="src-sym">(</span><span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1086"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1087"></a> <span class="src-var">$parts</span><span class="src-sym">[</span><span class="src-var">$k</span><span class="src-sym">] </span>= <a href="http://www.php.net/str_replace">str_replace</a><span class="src-sym">(</span><span class="src-var">$match</span><span class="src-sym">, </span><a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">'__'</span><span class="src-sym">, </span><span class="src-var">$e</span><span class="src-sym">)</span><span class="src-sym">, </span><span class="src-var">$parts</span><span class="src-sym">[</span><span class="src-var">$k</span><span class="src-sym">]</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1088"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1089"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1090"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1091"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1092"></a> <span class="src-var">$subquery </span>= <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">' '</span><span class="src-sym">, </span><span class="src-var">$parts</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1093"></a> <span class="src-key">return </span><span class="src-var">$subquery</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1094"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1095"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1096"></a><span class="src-doc"> * tokenizeQuery</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1097"></a><span class="src-doc"> * splits the given dql query into an array where keys</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1098"></a><span class="src-doc"> * represent different query part names and values are</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1099"></a><span class="src-doc"> * arrays splitted using sqlExplode method</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1100"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1101"></a><span class="src-doc"> * example:</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1102"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1103"></a><span class="src-doc"> * parameter:</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1104"></a><span class="src-doc"> * $query = "SELECT u.* FROM User u WHERE u.name LIKE ?"</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1105"></a><span class="src-doc"> * returns:</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1106"></a><span class="src-doc"> * array('select' => array('u.*'),</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1107"></a><span class="src-doc"> * 'from' => array('User', 'u'),</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1108"></a><span class="src-doc"> * 'where' => array('u.name', 'LIKE', '?'))</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1109"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1110"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$query </span><span class="src-doc"> DQL query</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1111"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@throws</span><span class="src-doc"> Doctrine_Query_Exception if some generic parsing error occurs</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1112"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">array </span><span class="src-doc"> an array containing the query string parts</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1113"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1114"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodtokenizeQuery">tokenizeQuery</a><span class="src-sym">(</span><span class="src-var">$query</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1115"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1116"></a> <span class="src-var">$e </span>= <span class="src-id"><a href="../Doctrine/Doctrine_Tokenizer.html">Doctrine_Tokenizer</a></span><span class="src-sym">::</span><a href="../Doctrine/Doctrine_Tokenizer.html#methodsqlExplode">sqlExplode</a><span class="src-sym">(</span><span class="src-var">$query</span><span class="src-sym">, </span><span class="src-str">' '</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1117"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1118"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-var">$e </span><span class="src-key">as </span><span class="src-var">$k</span>=><span class="src-var">$part</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1119"></a> <span class="src-var">$part </span>= <a href="http://www.php.net/trim">trim</a><span class="src-sym">(</span><span class="src-var">$part</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1120"></a> <span class="src-key">switch </span><span class="src-sym">(</span><a href="http://www.php.net/strtolower">strtolower</a><span class="src-sym">(</span><span class="src-var">$part</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1121"></a> <span class="src-key">case </span><span class="src-str">'delete'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1122"></a> <span class="src-key">case </span><span class="src-str">'update'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1123"></a> <span class="src-key">case </span><span class="src-str">'select'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1124"></a> <span class="src-key">case </span><span class="src-str">'set'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1125"></a> <span class="src-key">case </span><span class="src-str">'from'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1126"></a> <span class="src-key">case </span><span class="src-str">'where'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1127"></a> <span class="src-key">case </span><span class="src-str">'limit'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1128"></a> <span class="src-key">case </span><span class="src-str">'offset'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1129"></a> <span class="src-key">case </span><span class="src-str">'having'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1130"></a> <span class="src-var">$p </span>= <span class="src-var">$part</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1131"></a> <span class="src-var">$parts</span><span class="src-sym">[</span><span class="src-var">$part</span><span class="src-sym">] </span>= <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1132"></a> <span class="src-key">break</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1133"></a> <span class="src-key">case </span><span class="src-str">'order'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1134"></a> <span class="src-key">case </span><span class="src-str">'group'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1135"></a> <span class="src-var">$i </span>= <span class="src-sym">(</span><span class="src-var">$k </span>+ <span class="src-num">1</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1136"></a> <span class="src-key">if </span><span class="src-sym">(</span>isset<span class="src-sym">(</span><span class="src-var">$e</span><span class="src-sym">[</span><span class="src-var">$i</span><span class="src-sym">]</span><span class="src-sym">) </span>&& <a href="http://www.php.net/strtolower">strtolower</a><span class="src-sym">(</span><span class="src-var">$e</span><span class="src-sym">[</span><span class="src-var">$i</span><span class="src-sym">]</span><span class="src-sym">) </span>=== <span class="src-str">'by'</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1137"></a> <span class="src-var">$p </span>= <span class="src-var">$part</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1138"></a> <span class="src-var">$parts</span><span class="src-sym">[</span><span class="src-var">$part</span><span class="src-sym">] </span>= <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1139"></a> <span class="src-sym">} </span><span class="src-key">else </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1140"></a> <span class="src-var">$parts</span><span class="src-sym">[</span><span class="src-var">$p</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-sym">] </span>= <span class="src-var">$part</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1141"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1142"></a> <span class="src-key">break</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1143"></a> <span class="src-key">case </span><span class="src-str">'by'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1144"></a> <span class="src-key">continue</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1145"></a> <span class="src-key">default</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1146"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span>isset<span class="src-sym">(</span><span class="src-var">$p</span><span class="src-sym">))</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1147"></a> throw <span class="src-key">new </span><span class="src-id"><a href="../Doctrine/Doctrine_Query_Exception.html">Doctrine_Query_Exception</a></span><span class="src-sym">(</span><span class="src-str">"Couldn't parse query."</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1148"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1149"></a> <span class="src-var">$parts</span><span class="src-sym">[</span><span class="src-var">$p</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-sym">] </span>= <span class="src-var">$part</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1150"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1151"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1152"></a> <span class="src-key">return </span><span class="src-var">$parts</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1153"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1154"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1155"></a><span class="src-doc"> * DQL PARSER</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1156"></a><span class="src-doc"> * parses a DQL query</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1157"></a><span class="src-doc"> * first splits the query in parts and then uses individual</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1158"></a><span class="src-doc"> * parsers for each part</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1159"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1160"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$query </span><span class="src-doc"> DQL query</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1161"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">boolean </span><span class="src-doc-var">$clear </span><span class="src-doc"> whether or not to clear the aliases</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1162"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@throws</span><span class="src-doc"> Doctrine_Query_Exception if some generic parsing error occurs</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1163"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">Doctrine_Query </span></div></li>
|
||
|
<li><div class="src-line"><a name="a1164"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1165"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodparseQuery">parseQuery</a><span class="src-sym">(</span><span class="src-var">$query</span><span class="src-sym">, </span><span class="src-var">$clear </span>= <span class="src-id">true</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1166"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1167"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$clear</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1168"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodclear">clear</a><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1169"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1170"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1171"></a> <span class="src-var">$query </span>= <a href="http://www.php.net/trim">trim</a><span class="src-sym">(</span><span class="src-var">$query</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1172"></a> <span class="src-var">$query </span>= <a href="http://www.php.net/str_replace">str_replace</a><span class="src-sym">(</span><span class="src-str">"\n"</span><span class="src-sym">, </span><span class="src-str">' '</span><span class="src-sym">, </span><span class="src-var">$query</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1173"></a> <span class="src-var">$query </span>= <a href="http://www.php.net/str_replace">str_replace</a><span class="src-sym">(</span><span class="src-str">"\r"</span><span class="src-sym">, </span><span class="src-str">' '</span><span class="src-sym">, </span><span class="src-var">$query</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1174"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1175"></a> <span class="src-var">$parts </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodtokenizeQuery">tokenizeQuery</a><span class="src-sym">(</span><span class="src-var">$query</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1176"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1177"></a> <span class="src-key">foreach</span><span class="src-sym">(</span><span class="src-var">$parts </span><span class="src-key">as </span><span class="src-var">$k </span>=> <span class="src-var">$part</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1178"></a> <span class="src-var">$part </span>= <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">' '</span><span class="src-sym">, </span><span class="src-var">$part</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1179"></a> <span class="src-var">$k </span>= <a href="http://www.php.net/strtolower">strtolower</a><span class="src-sym">(</span><span class="src-var">$k</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1180"></a> <span class="src-key">switch </span><span class="src-sym">(</span><span class="src-var">$k</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1181"></a> <span class="src-key">case </span><span class="src-str">'create'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1182"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$type">type</a> = <span class="src-id">self</span><span class="src-sym">::</span><span class="src-id">CREATE</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1183"></a> <span class="src-key">break</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1184"></a> <span class="src-key">case </span><span class="src-str">'insert'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1185"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$type">type</a> = <span class="src-id">self</span><span class="src-sym">::</span><span class="src-id">INSERT</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1186"></a> <span class="src-key">break</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1187"></a> <span class="src-key">case </span><span class="src-str">'delete'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1188"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$type">type</a> = <span class="src-id">self</span><span class="src-sym">::</span><span class="src-id">DELETE</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1189"></a> <span class="src-key">break</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1190"></a> <span class="src-key">case </span><span class="src-str">'select'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1191"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$type">type</a> = <span class="src-id">self</span><span class="src-sym">::</span><span class="src-id">SELECT</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1192"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodparseQueryPart">parseQueryPart</a><span class="src-sym">(</span><span class="src-var">$k</span><span class="src-sym">, </span><span class="src-var">$part</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1193"></a> <span class="src-key">break</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1194"></a> <span class="src-key">case </span><span class="src-str">'update'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1195"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$type">type</a> = <span class="src-id">self</span><span class="src-sym">::</span><span class="src-id">UPDATE</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1196"></a> <span class="src-var">$k </span>= <span class="src-str">'from'</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1197"></a> <span class="src-key">case </span><span class="src-str">'from'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1198"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodparseQueryPart">parseQueryPart</a><span class="src-sym">(</span><span class="src-var">$k</span><span class="src-sym">, </span><span class="src-var">$part</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1199"></a> <span class="src-key">break</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1200"></a> <span class="src-key">case </span><span class="src-str">'set'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1201"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodparseQueryPart">parseQueryPart</a><span class="src-sym">(</span><span class="src-var">$k</span><span class="src-sym">, </span><span class="src-var">$part</span><span class="src-sym">, </span><span class="src-id">true</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1202"></a> <span class="src-key">break</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1203"></a> <span class="src-key">case </span><span class="src-str">'group'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1204"></a> <span class="src-key">case </span><span class="src-str">'order'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1205"></a> <span class="src-var">$k </span>.= <span class="src-str">'by'</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1206"></a> <span class="src-key">case </span><span class="src-str">'where'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1207"></a> <span class="src-key">case </span><span class="src-str">'having'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1208"></a> <span class="src-key">case </span><span class="src-str">'limit'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1209"></a> <span class="src-key">case </span><span class="src-str">'offset'</span>:</div></li>
|
||
|
<li><div class="src-line"><a name="a1210"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodparseQueryPart">parseQueryPart</a><span class="src-sym">(</span><span class="src-var">$k</span><span class="src-sym">, </span><span class="src-var">$part</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1211"></a> <span class="src-key">break</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1212"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1213"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1214"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1215"></a> <span class="src-key">return </span><span class="src-var">$this</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1216"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1217"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1218"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodload">load</a><span class="src-sym">(</span><span class="src-var">$path</span><span class="src-sym">, </span><span class="src-var">$loadFields </span>= <span class="src-id">true</span><span class="src-sym">) </span></div></li>
|
||
|
<li><div class="src-line"><a name="a1219"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1220"></a> <span class="src-comm">// parse custom join conditions</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1221"></a> <span class="src-var">$e </span>= <a href="http://www.php.net/explode">explode</a><span class="src-sym">(</span><span class="src-str">' ON '</span><span class="src-sym">, </span><span class="src-var">$path</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1222"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1223"></a> <span class="src-var">$joinCondition </span>= <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1224"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1225"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="../Doctrine/Doctrine_Query.html#methodcount">count</a><span class="src-sym">(</span><span class="src-var">$e</span><span class="src-sym">) </span>> <span class="src-num">1</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1226"></a> <span class="src-var">$joinCondition </span>= <span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">1</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1227"></a> <span class="src-var">$overrideJoin </span>= <span class="src-id">true</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1228"></a> <span class="src-var">$path </span>= <span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1229"></a> <span class="src-sym">} </span><span class="src-key">else </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1230"></a> <span class="src-var">$e </span>= <a href="http://www.php.net/explode">explode</a><span class="src-sym">(</span><span class="src-str">' WITH '</span><span class="src-sym">, </span><span class="src-var">$path</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1231"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1232"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="../Doctrine/Doctrine_Query.html#methodcount">count</a><span class="src-sym">(</span><span class="src-var">$e</span><span class="src-sym">) </span>> <span class="src-num">1</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1233"></a> <span class="src-var">$joinCondition </span>= <span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">1</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1234"></a> <span class="src-var">$path </span>= <span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1235"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1236"></a> <span class="src-var">$overrideJoin </span>= <span class="src-id">false</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1237"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1238"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1239"></a> <span class="src-var">$tmp </span>= <a href="http://www.php.net/explode">explode</a><span class="src-sym">(</span><span class="src-str">' '</span><span class="src-sym">, </span><span class="src-var">$path</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1240"></a> <span class="src-var">$componentAlias </span>= <span class="src-var">$originalAlias </span>= <span class="src-sym">(</span><a href="../Doctrine/Doctrine_Query.html#methodcount">count</a><span class="src-sym">(</span><span class="src-var">$tmp</span><span class="src-sym">) </span>> <span class="src-num">1</span><span class="src-sym">) </span>? <a href="http://www.php.net/end">end</a><span class="src-sym">(</span><span class="src-var">$tmp</span><span class="src-sym">) </span>: <span class="src-id">null</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1241"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1242"></a> <span class="src-var">$e </span>= <a href="http://www.php.net/preg_split">preg_split</a><span class="src-sym">(</span><span class="src-str">"/[.:]/"</span><span class="src-sym">, </span><span class="src-var">$tmp</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">, </span>-<span class="src-num">1</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1243"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1244"></a> <span class="src-var">$fullPath </span>= <span class="src-var">$tmp</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1245"></a> <span class="src-var">$prevPath </span>= <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1246"></a> <span class="src-var">$fullLength </span>= <a href="http://www.php.net/strlen">strlen</a><span class="src-sym">(</span><span class="src-var">$fullPath</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1247"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1248"></a> <span class="src-key">if </span><span class="src-sym">(</span>isset<span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_aliasMap">_aliasMap</a><span class="src-sym">[</span><span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]]</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1249"></a> <span class="src-var">$table </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_aliasMap">_aliasMap</a><span class="src-sym">[</span><span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]]</span><span class="src-sym">[</span><span class="src-str">'table'</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1250"></a> <span class="src-var">$componentAlias </span>= <span class="src-var">$e</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1251"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1252"></a> <span class="src-var">$prevPath </span>= <span class="src-var">$parent </span>= <a href="http://www.php.net/array_shift">array_shift</a><span class="src-sym">(</span><span class="src-var">$e</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1253"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1254"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1255"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-var">$e </span><span class="src-key">as </span><span class="src-var">$key </span>=> <span class="src-var">$name</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1256"></a> <span class="src-comm">// get length of the previous path</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1257"></a> <span class="src-var">$length </span>= <a href="http://www.php.net/strlen">strlen</a><span class="src-sym">(</span><span class="src-var">$prevPath</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1258"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1259"></a> <span class="src-comm">// build the current component path</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1260"></a> <span class="src-var">$prevPath </span>= <span class="src-sym">(</span><span class="src-var">$prevPath</span><span class="src-sym">) </span>? <span class="src-var">$prevPath </span>. <span class="src-str">'.' </span>. <span class="src-var">$name </span>: <span class="src-var">$name</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1261"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1262"></a> <span class="src-var">$delimeter </span>= <a href="http://www.php.net/substr">substr</a><span class="src-sym">(</span><span class="src-var">$fullPath</span><span class="src-sym">, </span><span class="src-var">$length</span><span class="src-sym">, </span><span class="src-num">1</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1263"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1264"></a> <span class="src-comm">// if an alias is not given use the current path as an alias identifier</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1265"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/strlen">strlen</a><span class="src-sym">(</span><span class="src-var">$prevPath</span><span class="src-sym">) </span>=== <span class="src-var">$fullLength </span>&& isset<span class="src-sym">(</span><span class="src-var">$originalAlias</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1266"></a> <span class="src-var">$componentAlias </span>= <span class="src-var">$originalAlias</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1267"></a> <span class="src-sym">} </span><span class="src-key">else </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1268"></a> <span class="src-var">$componentAlias </span>= <span class="src-var">$prevPath</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1269"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1270"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1271"></a> <span class="src-comm">// if the current alias already exists, skip it</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1272"></a> <span class="src-key">if </span><span class="src-sym">(</span>isset<span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_aliasMap">_aliasMap</a><span class="src-sym">[</span><span class="src-var">$componentAlias</span><span class="src-sym">]</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1273"></a> <span class="src-key">continue</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1274"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1275"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1276"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span>isset<span class="src-sym">(</span><span class="src-var">$table</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1277"></a> <span class="src-comm">// process the root of the path</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1278"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1279"></a> <span class="src-var">$table </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodloadRoot">loadRoot</a><span class="src-sym">(</span><span class="src-var">$name</span><span class="src-sym">, </span><span class="src-var">$componentAlias</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1280"></a> <span class="src-sym">} </span><span class="src-key">else </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1281"></a> <span class="src-var">$join </span>= <span class="src-sym">(</span><span class="src-var">$delimeter </span>== <span class="src-str">':'</span><span class="src-sym">) </span>? <span class="src-str">'INNER JOIN ' </span>: <span class="src-str">'LEFT JOIN '</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1282"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1283"></a> <span class="src-var">$relation </span>= <span class="src-var">$table</span><span class="src-sym">-></span><span class="src-id">getRelation</span><span class="src-sym">(</span><span class="src-var">$name</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1284"></a> <span class="src-var">$localTable </span>= <span class="src-var">$table</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1285"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1286"></a> <span class="src-var">$table </span>= <span class="src-var">$relation</span><span class="src-sym">-></span><span class="src-id">getTable</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1287"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_aliasMap">_aliasMap</a><span class="src-sym">[</span><span class="src-var">$componentAlias</span><span class="src-sym">] </span>= <span class="src-key">array</span><span class="src-sym">(</span><span class="src-str">'table' </span>=> <span class="src-var">$table</span><span class="src-sym">,</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1288"></a> <span class="src-str">'parent' </span>=> <span class="src-var">$parent</span><span class="src-sym">,</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1289"></a> <span class="src-str">'relation' </span>=> <span class="src-var">$relation</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1290"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span><span class="src-var">$relation</span><span class="src-sym">-></span><span class="src-id">isOneToOne</span><span class="src-sym">(</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1291"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$needsSubquery">needsSubquery</a> = <span class="src-id">true</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1292"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1293"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1294"></a> <span class="src-var">$localAlias </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodgetTableAlias">getTableAlias</a><span class="src-sym">(</span><span class="src-var">$parent</span><span class="src-sym">, </span><span class="src-var">$table</span><span class="src-sym">-></span><span class="src-id">getTableName</span><span class="src-sym">(</span><span class="src-sym">))</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1295"></a> <span class="src-var">$foreignAlias </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodgetTableAlias">getTableAlias</a><span class="src-sym">(</span><span class="src-var">$componentAlias</span><span class="src-sym">, </span><span class="src-var">$relation</span><span class="src-sym">-></span><span class="src-id">getTable</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">-></span><span class="src-id">getTableName</span><span class="src-sym">(</span><span class="src-sym">))</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1296"></a> <span class="src-var">$localSql </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$table</span><span class="src-sym">-></span><span class="src-id">getTableName</span><span class="src-sym">(</span><span class="src-sym">)) </span></div></li>
|
||
|
<li><div class="src-line"><a name="a1297"></a> . <span class="src-str">' ' </span></div></li>
|
||
|
<li><div class="src-line"><a name="a1298"></a> . <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$localAlias</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1299"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1300"></a> <span class="src-var">$foreignSql </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$relation</span><span class="src-sym">-></span><span class="src-id">getTable</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">-></span><span class="src-id">getTableName</span><span class="src-sym">(</span><span class="src-sym">)) </span></div></li>
|
||
|
<li><div class="src-line"><a name="a1301"></a> . <span class="src-str">' ' </span></div></li>
|
||
|
<li><div class="src-line"><a name="a1302"></a> . <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$foreignAlias</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1303"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1304"></a> <span class="src-var">$map </span>= <span class="src-var">$relation</span><span class="src-sym">-></span><span class="src-id">getTable</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">-></span><span class="src-id">inheritanceMap</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1305"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1306"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span><span class="src-var">$loadFields </span>|| <span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$map</span><span class="src-sym">) </span>|| <span class="src-var">$joinCondition</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1307"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$subqueryAliases">subqueryAliases</a><span class="src-sym">[</span><span class="src-sym">] </span>= <span class="src-var">$foreignAlias</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1308"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1309"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1310"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$relation </span>instanceof <span class="src-id"><a href="../Doctrine/Doctrine_Relation_Association.html">Doctrine_Relation_Association</a></span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1311"></a> <span class="src-var">$asf </span>= <span class="src-var">$relation</span><span class="src-sym">-></span><span class="src-id">getAssociationTable</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1312"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1313"></a> <span class="src-var">$assocTableName </span>= <span class="src-var">$asf</span><span class="src-sym">-></span><span class="src-id">getTableName</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1314"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1315"></a> <span class="src-key">if</span><span class="src-sym">( </span><span class="src-sym">! </span><span class="src-var">$loadFields </span>|| <span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$map</span><span class="src-sym">) </span>|| <span class="src-var">$joinCondition</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1316"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$subqueryAliases">subqueryAliases</a><span class="src-sym">[</span><span class="src-sym">] </span>= <span class="src-var">$assocTableName</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1317"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1318"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1319"></a> <span class="src-var">$assocPath </span>= <span class="src-var">$prevPath </span>. <span class="src-str">'.' </span>. <span class="src-var">$asf</span><span class="src-sym">-></span><span class="src-id">getComponentName</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1320"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1321"></a> <span class="src-var">$assocAlias </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodgetTableAlias">getTableAlias</a><span class="src-sym">(</span><span class="src-var">$assocPath</span><span class="src-sym">, </span><span class="src-var">$asf</span><span class="src-sym">-></span><span class="src-id">getTableName</span><span class="src-sym">(</span><span class="src-sym">))</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1322"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1323"></a> <span class="src-var">$queryPart </span>= <span class="src-var">$join </span>. <span class="src-var">$assocTableName </span>. <span class="src-str">' ' </span>. <span class="src-var">$assocAlias</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1324"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1325"></a> <span class="src-var">$queryPart </span>.= <span class="src-str">' ON ' </span>. <span class="src-var">$localAlias</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1326"></a> . <span class="src-str">'.'</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1327"></a> . <span class="src-var">$localTable</span><span class="src-sym">-></span><span class="src-id">getIdentifier</span><span class="src-sym">(</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1328"></a> . <span class="src-str">' = '</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1329"></a> . <span class="src-var">$assocAlias </span>. <span class="src-str">'.' </span>. <span class="src-var">$relation</span><span class="src-sym">-></span><span class="src-id">getLocal</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1330"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1331"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$relation</span><span class="src-sym">-></span><span class="src-id">isEqual</span><span class="src-sym">(</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1332"></a> <span class="src-comm">// equal nest relation needs additional condition</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1333"></a> <span class="src-var">$queryPart </span>.= <span class="src-str">' OR ' </span>. <span class="src-var">$localAlias</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1334"></a> . <span class="src-str">'.'</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1335"></a> . <span class="src-var">$table</span><span class="src-sym">-></span><span class="src-id">getColumnName</span><span class="src-sym">(</span><span class="src-var">$table</span><span class="src-sym">-></span><span class="src-id">getIdentifier</span><span class="src-sym">(</span><span class="src-sym">))</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1336"></a> . <span class="src-str">' = '</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1337"></a> . <span class="src-var">$assocAlias </span>. <span class="src-str">'.' </span>. <span class="src-var">$relation</span><span class="src-sym">-></span><span class="src-id">getForeign</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1338"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1339"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1340"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1341"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'from'</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-sym">] </span>= <span class="src-var">$queryPart</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1342"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1343"></a> <span class="src-var">$queryPart </span>= <span class="src-var">$join </span>. <span class="src-var">$foreignSql</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1344"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1345"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span><span class="src-var">$overrideJoin</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1346"></a> <span class="src-var">$queryPart </span>.= <span class="src-str">' ON '</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1347"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1348"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$relation</span><span class="src-sym">-></span><span class="src-id">isEqual</span><span class="src-sym">(</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1349"></a> <span class="src-var">$queryPart </span>.= <span class="src-str">'('</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1350"></a> <span class="src-sym">} </span></div></li>
|
||
|
<li><div class="src-line"><a name="a1351"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1352"></a> <span class="src-var">$queryPart </span>.= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$foreignAlias </span>. <span class="src-str">'.' </span>. <span class="src-var">$relation</span><span class="src-sym">-></span><span class="src-id">getTable</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">-></span><span class="src-id">getIdentifier</span><span class="src-sym">(</span><span class="src-sym">))</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1353"></a> . <span class="src-str">' = '</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1354"></a> . <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$assocAlias </span>. <span class="src-str">'.' </span>. <span class="src-var">$relation</span><span class="src-sym">-></span><span class="src-id">getForeign</span><span class="src-sym">(</span><span class="src-sym">))</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1355"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1356"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$relation</span><span class="src-sym">-></span><span class="src-id">isEqual</span><span class="src-sym">(</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1357"></a> <span class="src-var">$queryPart </span>.= <span class="src-str">' OR '</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1358"></a> . <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$foreignAlias </span>. <span class="src-str">'.' </span>. <span class="src-var">$table</span><span class="src-sym">-></span><span class="src-id">getColumnName</span><span class="src-sym">(</span><span class="src-var">$table</span><span class="src-sym">-></span><span class="src-id">getIdentifier</span><span class="src-sym">(</span><span class="src-sym">)))</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1359"></a> . <span class="src-str">' = ' </span></div></li>
|
||
|
<li><div class="src-line"><a name="a1360"></a> . <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$assocAlias </span>. <span class="src-str">'.' </span>. <span class="src-var">$relation</span><span class="src-sym">-></span><span class="src-id">getLocal</span><span class="src-sym">(</span><span class="src-sym">))</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1361"></a> . <span class="src-str">') AND ' </span></div></li>
|
||
|
<li><div class="src-line"><a name="a1362"></a> . <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$foreignAlias </span>. <span class="src-str">'.' </span>. <span class="src-var">$table</span><span class="src-sym">-></span><span class="src-id">getIdentifier</span><span class="src-sym">(</span><span class="src-sym">))</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1363"></a> . <span class="src-str">' != ' </span></div></li>
|
||
|
<li><div class="src-line"><a name="a1364"></a> . <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$localAlias </span>. <span class="src-str">'.' </span>. <span class="src-var">$table</span><span class="src-sym">-></span><span class="src-id">getIdentifier</span><span class="src-sym">(</span><span class="src-sym">))</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1365"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1366"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1367"></a> <span class="src-sym">} </span><span class="src-key">else </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1368"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1369"></a> <span class="src-var">$queryPart </span>= <span class="src-var">$join </span>. <span class="src-var">$foreignSql</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1370"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1371"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span><span class="src-var">$overrideJoin</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1372"></a> <span class="src-var">$queryPart </span>.= <span class="src-str">' ON '</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1373"></a> . <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$localAlias </span>. <span class="src-str">'.' </span>. <span class="src-var">$relation</span><span class="src-sym">-></span><span class="src-id">getLocal</span><span class="src-sym">(</span><span class="src-sym">))</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1374"></a> . <span class="src-str">' = ' </span></div></li>
|
||
|
<li><div class="src-line"><a name="a1375"></a> . <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$foreignAlias </span>. <span class="src-str">'.' </span>. <span class="src-var">$relation</span><span class="src-sym">-></span><span class="src-id">getForeign</span><span class="src-sym">(</span><span class="src-sym">))</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1376"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1377"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1378"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1379"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'from'</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-var">$componentAlias</span><span class="src-sym">] </span>= <span class="src-var">$queryPart</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1380"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$joinCondition</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1381"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_pendingJoinConditions">_pendingJoinConditions</a><span class="src-sym">[</span><span class="src-var">$componentAlias</span><span class="src-sym">] </span>= <span class="src-var">$joinCondition</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1382"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1383"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1384"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$loadFields</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1385"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1386"></a> <span class="src-var">$restoreState </span>= <span class="src-id">false</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1387"></a> <span class="src-comm">// load fields if necessary</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1388"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$loadFields </span>&& <span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$pendingFields">pendingFields</a><span class="src-sym">) </span></div></li>
|
||
|
<li><div class="src-line"><a name="a1389"></a> && <span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$pendingAggregates">pendingAggregates</a><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1390"></a> && <span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$pendingSubqueries">pendingSubqueries</a><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1391"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1392"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$pendingFields">pendingFields</a><span class="src-sym">[</span><span class="src-var">$componentAlias</span><span class="src-sym">] </span>= <span class="src-key">array</span><span class="src-sym">(</span><span class="src-str">'*'</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1393"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1394"></a> <span class="src-var">$restoreState </span>= <span class="src-id">true</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1395"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1396"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1397"></a> <span class="src-key">if</span><span class="src-sym">(</span>isset<span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$pendingFields">pendingFields</a><span class="src-sym">[</span><span class="src-var">$componentAlias</span><span class="src-sym">]</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1398"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodprocessPendingFields">processPendingFields</a><span class="src-sym">(</span><span class="src-var">$componentAlias</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1399"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1400"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1401"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$restoreState</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1402"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$pendingFields">pendingFields</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1403"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$pendingAggregates">pendingAggregates</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1404"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1405"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1406"></a> <span class="src-var">$parent </span>= <span class="src-var">$prevPath</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1407"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1408"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1409"></a> <span class="src-key">return </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_aliasMap">_aliasMap</a><span class="src-sym">[</span><span class="src-var">$componentAlias</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1410"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1411"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1412"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1413"></a><span class="src-doc"> * loadRoot</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1414"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1415"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$name </span></div></li>
|
||
|
<li><div class="src-line"><a name="a1416"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$componentAlias </span></div></li>
|
||
|
<li><div class="src-line"><a name="a1417"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1418"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodloadRoot">loadRoot</a><span class="src-sym">(</span><span class="src-var">$name</span><span class="src-sym">, </span><span class="src-var">$componentAlias</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1419"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1420"></a> <span class="src-comm">// get the connection for the component</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1421"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a> = <span class="src-id"><a href="../Doctrine/Doctrine_Manager.html">Doctrine_Manager</a></span><span class="src-sym">::</span><a href="../Doctrine/Doctrine_Manager.html#methodgetInstance">getInstance</a><span class="src-sym">(</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1422"></a> <span class="src-sym">-></span><span class="src-id">getConnectionForComponent</span><span class="src-sym">(</span><span class="src-var">$name</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1423"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1424"></a> <span class="src-var">$table </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">getTable</span><span class="src-sym">(</span><span class="src-var">$name</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1425"></a> <span class="src-var">$tableName </span>= <span class="src-var">$table</span><span class="src-sym">-></span><span class="src-id">getTableName</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1426"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1427"></a> <span class="src-comm">// get the short alias for this table</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1428"></a> <span class="src-var">$tableAlias </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodgetTableAlias">getTableAlias</a><span class="src-sym">(</span><span class="src-var">$componentAlias</span><span class="src-sym">, </span><span class="src-var">$tableName</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1429"></a> <span class="src-comm">// quote table name</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1430"></a> <span class="src-var">$queryPart </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$tableName</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1431"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1432"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$type">type</a> === <span class="src-id">self</span><span class="src-sym">::</span><span class="src-id">SELECT</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1433"></a> <span class="src-var">$queryPart </span>.= <span class="src-str">' ' </span>. <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_conn">_conn</a><span class="src-sym">-></span><span class="src-id">quoteIdentifier</span><span class="src-sym">(</span><span class="src-var">$tableAlias</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1434"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1435"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1436"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'from'</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-sym">] </span>= <span class="src-var">$queryPart</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1437"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-var">tableAliases</span><span class="src-sym">[</span><span class="src-var">$tableAlias</span><span class="src-sym">] </span>= <span class="src-var">$componentAlias</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1438"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_aliasMap">_aliasMap</a><span class="src-sym">[</span><span class="src-var">$componentAlias</span><span class="src-sym">] </span>= <span class="src-key">array</span><span class="src-sym">(</span><span class="src-str">'table' </span>=> <span class="src-var">$table</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1439"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1440"></a> <span class="src-key">return </span><span class="src-var">$table</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1441"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1442"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1443"></a><span class="src-doc"> * count</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1444"></a><span class="src-doc"> * fetches the count of the query</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1445"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1446"></a><span class="src-doc"> * This method executes the main query without all the</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1447"></a><span class="src-doc"> * selected fields, ORDER BY part, LIMIT part and OFFSET part.</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1448"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1449"></a><span class="src-doc"> * Example:</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1450"></a><span class="src-doc"> * Main query:</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1451"></a><span class="src-doc"> * SELECT u.*, p.phonenumber FROM User u</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1452"></a><span class="src-doc"> * LEFT JOIN u.Phonenumber p</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1453"></a><span class="src-doc"> * WHERE p.phonenumber = '123 123' LIMIT 10</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1454"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1455"></a><span class="src-doc"> * The modified DQL query:</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1456"></a><span class="src-doc"> * SELECT COUNT(DISTINCT u.id) FROM User u</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1457"></a><span class="src-doc"> * LEFT JOIN u.Phonenumber p</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1458"></a><span class="src-doc"> * WHERE p.phonenumber = '123 123'</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1459"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1460"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">array </span><span class="src-doc-var">$params </span><span class="src-doc"> an array of prepared statement parameters</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1461"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">integer </span><span class="src-doc"> the count of this query</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1462"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1463"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodcount">count</a><span class="src-sym">(</span><span class="src-var">$params </span>= <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">))</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1464"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1465"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodgetQuery">getQuery</a><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1466"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1467"></a> <span class="src-comm">// initialize temporary variables</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1468"></a> <span class="src-var">$where </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'where'</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1469"></a> <span class="src-var">$having </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'having'</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1470"></a> <span class="src-var">$groupby </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'groupby'</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1471"></a> <span class="src-var">$map </span>= <a href="../Doctrine/Doctrine_Query.html#methodreset">reset</a><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_aliasMap">_aliasMap</a><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1472"></a> <span class="src-var">$componentAlias </span>= <a href="http://www.php.net/key">key</a><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_aliasMap">_aliasMap</a><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1473"></a> <span class="src-var">$table </span>= <span class="src-var">$map</span><span class="src-sym">[</span><span class="src-str">'table'</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1474"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1475"></a> <span class="src-comm">// build the query base</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1476"></a> <span class="src-var">$q </span>= <span class="src-str">'SELECT COUNT(DISTINCT ' </span>. <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodgetTableAlias">getTableAlias</a><span class="src-sym">(</span><span class="src-var">$componentAlias</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1477"></a> . <span class="src-str">'.' </span>. <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">','</span><span class="src-sym">, </span>(array) <span class="src-var">$table</span><span class="src-sym">-></span><span class="src-id">getIdentifier</span><span class="src-sym">(</span><span class="src-sym">))</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1478"></a> . <span class="src-str">') AS num_results'</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1479"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1480"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$parts">parts</a><span class="src-sym">[</span><span class="src-str">'select'</span><span class="src-sym">] </span><span class="src-key">as </span><span class="src-var">$field</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1481"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/strpos">strpos</a><span class="src-sym">(</span><span class="src-var">$field</span><span class="src-sym">, </span><span class="src-str">'('</span><span class="src-sym">) </span>!== <span class="src-id">false</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1482"></a> <span class="src-var">$q </span>.= <span class="src-str">', ' </span>. <span class="src-var">$field</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1483"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1484"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1485"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1486"></a> <span class="src-var">$q </span>.= <span class="src-str">' FROM ' </span>. <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodbuildFromPart">buildFromPart</a><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1487"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1488"></a> <span class="src-comm">// append column aggregation inheritance (if needed)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1489"></a> <span class="src-var">$string </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodapplyInheritance">applyInheritance</a><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1490"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1491"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$string</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1492"></a> <span class="src-var">$where</span><span class="src-sym">[</span><span class="src-sym">] </span>= <span class="src-var">$string</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1493"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1494"></a> <span class="src-comm">// append conditions</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1495"></a> <span class="src-var">$q </span>.= <span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$where</span><span class="src-sym">)) </span>? <span class="src-str">' WHERE ' </span>. <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">' AND '</span><span class="src-sym">, </span><span class="src-var">$where</span><span class="src-sym">) </span>: <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1496"></a> <span class="src-var">$q </span>.= <span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$groupby</span><span class="src-sym">)) </span>? <span class="src-str">' GROUP BY ' </span>. <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">', '</span><span class="src-sym">, </span><span class="src-var">$groupby</span><span class="src-sym">) </span>: <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1497"></a> <span class="src-var">$q </span>.= <span class="src-sym">( </span><span class="src-sym">! </span><span class="src-key">empty</span><span class="src-sym">(</span><span class="src-var">$having</span><span class="src-sym">)) </span>? <span class="src-str">' HAVING ' </span>. <a href="http://www.php.net/implode">implode</a><span class="src-sym">(</span><span class="src-str">' AND '</span><span class="src-sym">, </span><span class="src-var">$having</span><span class="src-sym">)</span>: <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1498"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1499"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span><a href="http://www.php.net/is_array">is_array</a><span class="src-sym">(</span><span class="src-var">$params</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1500"></a> <span class="src-var">$params </span>= <span class="src-key">array</span><span class="src-sym">(</span><span class="src-var">$params</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1501"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1502"></a> <span class="src-comm">// append parameters</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1503"></a> <span class="src-var">$params </span>= <a href="http://www.php.net/array_merge">array_merge</a><span class="src-sym">(</span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#var$_params">_params</a><span class="src-sym">, </span><span class="src-var">$params</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1504"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1505"></a> <span class="src-var">$results </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodgetConnection">getConnection</a><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">-></span><span class="src-id">fetchAll</span><span class="src-sym">(</span><span class="src-var">$q</span><span class="src-sym">, </span><span class="src-var">$params</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1506"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1507"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="../Doctrine/Doctrine_Query.html#methodcount">count</a><span class="src-sym">(</span><span class="src-var">$results</span><span class="src-sym">) </span>> <span class="src-num">1</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1508"></a> <span class="src-var">$count </span>= <span class="src-num">0</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1509"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-var">$results </span><span class="src-key">as </span><span class="src-var">$result</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1510"></a> <span class="src-var">$count </span>+= <span class="src-var">$result</span><span class="src-sym">[</span><span class="src-str">'num_results'</span><span class="src-sym">]</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1511"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1512"></a> <span class="src-sym">} </span><span class="src-key">else </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1513"></a> <span class="src-var">$count </span>= isset<span class="src-sym">(</span><span class="src-var">$results</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">) </span>? <span class="src-var">$results</span><span class="src-sym">[</span><span class="src-num">0</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-str">'num_results'</span><span class="src-sym">]</span>:<span class="src-num">0</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1514"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1515"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1516"></a> <span class="src-key">return </span>(int) <span class="src-var">$count</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1517"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1518"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1519"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1520"></a><span class="src-doc"> * query</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1521"></a><span class="src-doc"> * query the database with DQL (Doctrine Query Language)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1522"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1523"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$query </span><span class="src-doc"> DQL query</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1524"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">array </span><span class="src-doc-var">$params </span><span class="src-doc"> prepared statement parameters</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1525"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@see</span><span class="src-doc"> Doctrine::FETCH_* constants</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1526"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">mixed </span></div></li>
|
||
|
<li><div class="src-line"><a name="a1527"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1528"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodquery">query</a><span class="src-sym">(</span><span class="src-var">$query</span><span class="src-sym">, </span><span class="src-var">$params </span>= <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">))</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1529"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1530"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodparseQuery">parseQuery</a><span class="src-sym">(</span><span class="src-var">$query</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1531"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1532"></a> <span class="src-key">return </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodexecute">execute</a><span class="src-sym">(</span><span class="src-var">$params</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1533"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1534"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1535"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodcopy">copy</a><span class="src-sym">(</span><span class="src-id">Doctrine_Query </span><span class="src-var">$query </span>= <span class="src-id">null</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1536"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1537"></a> <span class="src-key">if </span><span class="src-sym">( </span><span class="src-sym">! </span><span class="src-var">$query</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1538"></a> <span class="src-var">$query </span>= <span class="src-var">$this</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1539"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1540"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1541"></a> <span class="src-var">$new </span>= <span class="src-key">new </span><span class="src-id"><a href="../Doctrine/Doctrine_Query.html">Doctrine_Query</a></span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1542"></a> <span class="src-var">$new</span><span class="src-sym">-></span><span class="src-id">_dqlParts </span>= <span class="src-var">$query</span><span class="src-sym">-></span><span class="src-id">_dqlParts</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1543"></a> <span class="src-var">$new</span><span class="src-sym">-></span><span class="src-id">_hydrationMode </span>= <span class="src-var">$query</span><span class="src-sym">-></span><span class="src-id">_hydrationMode</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1544"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1545"></a> <span class="src-key">return </span><span class="src-var">$new</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1546"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1547"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a1548"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1549"></a><span class="src-doc"> * Frees the resources used by the query object. It especially breaks a</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1550"></a><span class="src-doc"> * cyclic reference between the query object and it's parsers. This enables</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1551"></a><span class="src-doc"> * PHP's current GC to reclaim the memory.</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1552"></a><span class="src-doc"> * This method can therefore be used to reduce memory usage when creating a lot</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1553"></a><span class="src-doc"> * of query objects during a request.</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1554"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1555"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">Doctrine_Query </span><span class="src-doc"> this object</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1556"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1557"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Query.html#methodfree">free</a><span class="src-sym">(</span><span class="src-sym">) </span></div></li>
|
||
|
<li><div class="src-line"><a name="a1558"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1559"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#methodreset">reset</a><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1560"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_parsers">_parsers</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1561"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_dqlParts">_dqlParts</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1562"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Query.html#var$_enumParams">_enumParams</a> = <span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1563"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a1564"></a><span class="src-sym">}</span></div></li>
|
||
|
</ol>
|
||
|
</span></div>
|
||
|
</div>
|