290 lines
81 KiB
HTML
290 lines
81 KiB
HTML
|
|
<div id="content">
|
|
<h1 align="center">Source for file RawSql.php</h1>
|
|
<p>Documentation is available at <a href="../Doctrine/_Doctrine---RawSql.php.html">RawSql.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: RawSql.php 1847 2007-06-26 10:05:26Z 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_RawSql</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: 1847 $</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_RawSql.html">Doctrine_RawSql</a> <span class="src-key">extends </span><a href="../Doctrine/Doctrine_Query_Abstract.html">Doctrine_Query_Abstract</a></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-doc">/**</span></div></li>
|
|
<li><div class="src-line"><a name="a36"></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">$fields </span></div></li>
|
|
<li><div class="src-line"><a name="a37"></a><span class="src-doc"> */</span></div></li>
|
|
<li><div class="src-line"><a name="a38"></a> <span class="src-key">private </span><a href="../Doctrine/Doctrine_RawSql.html#var$fields">$fields</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="a39"></a> <span class="src-doc">/**</span></div></li>
|
|
<li><div class="src-line"><a name="a40"></a><span class="src-doc"> * parseQueryPart</span></div></li>
|
|
<li><div class="src-line"><a name="a41"></a><span class="src-doc"> * parses given query part</span></div></li>
|
|
<li><div class="src-line"><a name="a42"></a><span class="src-doc"> *</span></div></li>
|
|
<li><div class="src-line"><a name="a43"></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="a44"></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="a45"></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="a46"></a><span class="src-doc"> * if false is given, this method will overwrite</span></div></li>
|
|
<li><div class="src-line"><a name="a47"></a><span class="src-doc"> * the given query part stack with $queryPart</span></div></li>
|
|
<li><div class="src-line"><a name="a48"></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="a49"></a><span class="src-doc"> */</span></div></li>
|
|
<li><div class="src-line"><a name="a50"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_RawSql.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="a51"></a> <span class="src-sym">{</span></div></li>
|
|
<li><div class="src-line"><a name="a52"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$queryPartName </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="a53"></a> <a href="http://www.php.net/preg_match_all">preg_match_all</a><span class="src-sym">(</span><span class="src-str">'/{([^}{]*)}/U'</span><span class="src-sym">, </span><span class="src-var">$queryPart</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="a54"></a> </div></li>
|
|
<li><div class="src-line"><a name="a55"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_RawSql.html#var$fields">fields</a> = <span class="src-var">$m</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="a56"></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-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="a57"></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="a58"></a> <span class="src-key">if </span><span class="src-sym">( </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="a59"></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-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="a60"></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="a61"></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-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="a62"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a63"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a64"></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="a65"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a66"></a> <span class="src-doc">/**</span></div></li>
|
|
<li><div class="src-line"><a name="a67"></a><span class="src-doc"> * parseQuery</span></div></li>
|
|
<li><div class="src-line"><a name="a68"></a><span class="src-doc"> * parses an sql query and adds the parts to internal array</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">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$query </span><span class="src-doc"> query to be parsed</span></div></li>
|
|
<li><div class="src-line"><a name="a71"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">Doctrine_RawSql </span><span class="src-doc"> this object</span></div></li>
|
|
<li><div class="src-line"><a name="a72"></a><span class="src-doc"> */</span></div></li>
|
|
<li><div class="src-line"><a name="a73"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_RawSql.html#methodparseQuery">parseQuery</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="a74"></a> <span class="src-sym">{</span></div></li>
|
|
<li><div class="src-line"><a name="a75"></a> <a href="http://www.php.net/preg_match_all">preg_match_all</a><span class="src-sym">(</span><span class="src-str">'/{([^}{]*)}/U'</span><span class="src-sym">, </span><span class="src-var">$query</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="a76"></a> </div></li>
|
|
<li><div class="src-line"><a name="a77"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_RawSql.html#var$fields">fields</a> = <span class="src-var">$m</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="a78"></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="a79"></a> </div></li>
|
|
<li><div class="src-line"><a name="a80"></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="a81"></a> </div></li>
|
|
<li><div class="src-line"><a name="a82"></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="a83"></a> <span class="src-var">$low </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="a84"></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="a85"></a> <span class="src-key">case </span><span class="src-str">'select'</span>:</div></li>
|
|
<li><div class="src-line"><a name="a86"></a> <span class="src-key">case </span><span class="src-str">'from'</span>:</div></li>
|
|
<li><div class="src-line"><a name="a87"></a> <span class="src-key">case </span><span class="src-str">'where'</span>:</div></li>
|
|
<li><div class="src-line"><a name="a88"></a> <span class="src-key">case </span><span class="src-str">'limit'</span>:</div></li>
|
|
<li><div class="src-line"><a name="a89"></a> <span class="src-key">case </span><span class="src-str">'offset'</span>:</div></li>
|
|
<li><div class="src-line"><a name="a90"></a> <span class="src-key">case </span><span class="src-str">'having'</span>:</div></li>
|
|
<li><div class="src-line"><a name="a91"></a> <span class="src-var">$p </span>= <span class="src-var">$low</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a92"></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">$parts</span><span class="src-sym">[</span><span class="src-var">$low</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-var">$parts</span><span class="src-sym">[</span><span class="src-var">$low</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="a94"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a95"></a> <span class="src-key">break</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a96"></a> <span class="src-key">case </span><span class="src-str">'order'</span>:</div></li>
|
|
<li><div class="src-line"><a name="a97"></a> <span class="src-key">case </span><span class="src-str">'group'</span>:</div></li>
|
|
<li><div class="src-line"><a name="a98"></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="a99"></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="a100"></a> <span class="src-var">$p </span>= <span class="src-var">$low</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a101"></a> <span class="src-var">$p </span>.= <span class="src-str">'by'</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a102"></a> <span class="src-var">$parts</span><span class="src-sym">[</span><span class="src-var">$low </span>. <span class="src-str">'by'</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="a103"></a> </div></li>
|
|
<li><div class="src-line"><a name="a104"></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="a105"></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="a106"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a107"></a> <span class="src-key">break</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a108"></a> <span class="src-key">case </span><span class="src-str">'by'</span>:</div></li>
|
|
<li><div class="src-line"><a name="a109"></a> <span class="src-key">continue</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a110"></a> <span class="src-key">default</span>:</div></li>
|
|
<li><div class="src-line"><a name="a111"></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">$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-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="a112"></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-num">0</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="a113"></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="a114"></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-num">0</span><span class="src-sym">] </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="a115"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a116"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a117"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a118"></a> </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_Hydrate.html#var$parts">parts</a> = <span class="src-var">$parts</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_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">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> </div></li>
|
|
<li><div class="src-line"><a name="a122"></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="a123"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a124"></a> <span class="src-doc">/**</span></div></li>
|
|
<li><div class="src-line"><a name="a125"></a><span class="src-doc"> * getQuery</span></div></li>
|
|
<li><div class="src-line"><a name="a126"></a><span class="src-doc"> * builds the sql query from the given query parts</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">@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="a129"></a><span class="src-doc"> */</span></div></li>
|
|
<li><div class="src-line"><a name="a130"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_RawSql.html#methodgetQuery">getQuery</a><span class="src-sym">(</span><span class="src-sym">)</span></div></li>
|
|
<li><div class="src-line"><a name="a131"></a> <span class="src-sym">{</span></div></li>
|
|
<li><div class="src-line"><a name="a132"></a> <span class="src-var">$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="a133"></a> </div></li>
|
|
<li><div class="src-line"><a name="a134"></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_RawSql.html#var$fields">fields</a> <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="a135"></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">$field</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-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">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="a137"></a> throw <span class="src-key">new </span><span class="src-id"><a href="../Doctrine/Doctrine_RawSql_Exception.html">Doctrine_RawSql_Exception</a></span><span class="src-sym">(</span><span class="src-str">'All selected fields in Sql query must be in format tableAlias.fieldName'</span><span class="src-sym">)</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-comm">// try to auto-add component</span></div></li>
|
|
<li><div class="src-line"><a name="a140"></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_Hydrate.html#methodhasTableAlias">hasTableAlias</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="a141"></a> try <span class="src-sym">{</span></div></li>
|
|
<li><div class="src-line"><a name="a142"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_RawSql.html#methodaddComponent">addComponent</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><a href="http://www.php.net/ucwords">ucwords</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="a143"></a> <span class="src-sym">} </span>catch<span class="src-sym">(</span><span class="src-id"><a href="../Doctrine/Doctrine_Exception.html">Doctrine_Exception</a> </span><span class="src-var">$exception</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
|
<li><div class="src-line"><a name="a144"></a> throw <span class="src-key">new </span><span class="src-id"><a href="../Doctrine/Doctrine_RawSql_Exception.html">Doctrine_RawSql_Exception</a></span><span class="src-sym">(</span><span class="src-str">'The associated component for table alias ' </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-str">' couldn\'t be found.'</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a145"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a146"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a147"></a> </div></li>
|
|
<li><div class="src-line"><a name="a148"></a> <span class="src-var">$componentAlias </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodgetComponentAlias">getComponentAlias</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="a149"></a> </div></li>
|
|
<li><div class="src-line"><a name="a150"></a> <span class="src-key">if </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-str">'*'</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
|
<li><div class="src-line"><a name="a151"></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$_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><span class="src-id">getColumnNames</span><span class="src-sym">(</span><span class="src-sym">) </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="a152"></a> <span class="src-var">$field </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-str">'.' </span>. <span class="src-var">$name</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a153"></a> </div></li>
|
|
<li><div class="src-line"><a name="a154"></a> <span class="src-var">$select</span><span class="src-sym">[</span><span class="src-var">$componentAlias</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-var">$field</span><span class="src-sym">] </span>= <span class="src-var">$field </span>. <span class="src-str">' AS ' </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-str">'__' </span>. <span class="src-var">$name</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a155"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a156"></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="a157"></a> <span class="src-var">$field </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-str">'.' </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="a158"></a> <span class="src-var">$select</span><span class="src-sym">[</span><span class="src-var">$componentAlias</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-var">$field</span><span class="src-sym">] </span>= <span class="src-var">$field </span>. <span class="src-str">' AS ' </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-str">'__' </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="a159"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a160"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a161"></a> </div></li>
|
|
<li><div class="src-line"><a name="a162"></a> <span class="src-comm">// force-add all primary key fields</span></div></li>
|
|
<li><div class="src-line"><a name="a163"></a> </div></li>
|
|
<li><div class="src-line"><a name="a164"></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#methodgetTableAliases">getTableAliases</a><span class="src-sym">(</span><span class="src-sym">) </span><span class="src-key">as </span><span class="src-var">$tableAlias </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="a165"></a> <span class="src-var">$map </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="a166"></a> </div></li>
|
|
<li><div class="src-line"><a name="a167"></a> <span class="src-key">foreach </span><span class="src-sym">(</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><span class="src-id">getPrimaryKeys</span><span class="src-sym">(</span><span class="src-sym">) </span><span class="src-key">as </span><span class="src-var">$key</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
|
<li><div class="src-line"><a name="a168"></a> <span class="src-var">$field </span>= <span class="src-var">$tableAlias </span>. <span class="src-str">'.' </span>. <span class="src-var">$key</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a169"></a> </div></li>
|
|
<li><div class="src-line"><a name="a170"></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$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-var">$field</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="a171"></a> <span class="src-var">$select</span><span class="src-sym">[</span><span class="src-var">$componentAlias</span><span class="src-sym">]</span><span class="src-sym">[</span><span class="src-var">$field</span><span class="src-sym">] </span>= <span class="src-var">$field </span>. <span class="src-str">' AS ' </span>. <span class="src-var">$tableAlias </span>. <span class="src-str">'__' </span>. <span class="src-var">$key</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a172"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a173"></a> <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> </div></li>
|
|
<li><div class="src-line"><a name="a176"></a> <span class="src-comm">// first add the fields of the root component</span></div></li>
|
|
<li><div class="src-line"><a name="a177"></a> <a href="http://www.php.net/reset">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="a178"></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="a179"></a> </div></li>
|
|
<li><div class="src-line"><a name="a180"></a> <span class="src-var">$q </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">$select</span><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="a181"></a> unset<span class="src-sym">(</span><span class="src-var">$select</span><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="a182"></a> </div></li>
|
|
<li><div class="src-line"><a name="a183"></a> <span class="src-key">foreach </span><span class="src-sym">(</span><span class="src-var">$select </span><span class="src-key">as </span><span class="src-var">$component </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="a184"></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">$fields</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
|
<li><div class="src-line"><a name="a185"></a> <span class="src-var">$q </span>.= <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><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="a186"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a187"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a188"></a> </div></li>
|
|
<li><div class="src-line"><a name="a189"></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="a190"></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="a191"></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-var">$string</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a192"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a193"></a> <span class="src-var">$copy </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></div></li>
|
|
<li><div class="src-line"><a name="a194"></a> unset<span class="src-sym">(</span><span class="src-var">$copy</span><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></div></li>
|
|
<li><div class="src-line"><a name="a195"></a> </div></li>
|
|
<li><div class="src-line"><a name="a196"></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">'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_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-str">''</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a197"></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="a198"></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="a199"></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="a200"></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="a201"></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">'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_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-str">''</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a202"></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">'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_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-str">''</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a203"></a> </div></li>
|
|
<li><div class="src-line"><a name="a204"></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="a205"></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="a206"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a207"></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="a208"></a> <span class="src-sym">}</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"> * getFields</span></div></li>
|
|
<li><div class="src-line"><a name="a211"></a><span class="src-doc"> * returns the fields associated with this parser</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">@return </span><span class="src-doc-type">array </span><span class="src-doc"> all the fields associated with this parser</span></div></li>
|
|
<li><div class="src-line"><a name="a214"></a><span class="src-doc"> */</span></div></li>
|
|
<li><div class="src-line"><a name="a215"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_RawSql.html#methodgetFields">getFields</a><span class="src-sym">(</span><span class="src-sym">)</span></div></li>
|
|
<li><div class="src-line"><a name="a216"></a> <span class="src-sym">{</span></div></li>
|
|
<li><div class="src-line"><a name="a217"></a> <span class="src-key">return </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_RawSql.html#var$fields">fields</a><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a218"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a219"></a> <span class="src-doc">/**</span></div></li>
|
|
<li><div class="src-line"><a name="a220"></a><span class="src-doc"> * addComponent</span></div></li>
|
|
<li><div class="src-line"><a name="a221"></a><span class="src-doc"> *</span></div></li>
|
|
<li><div class="src-line"><a name="a222"></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">$tableAlias </span></div></li>
|
|
<li><div class="src-line"><a name="a223"></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">$componentName </span></div></li>
|
|
<li><div class="src-line"><a name="a224"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">Doctrine_RawSql </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-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_RawSql.html#methodaddComponent">addComponent</a><span class="src-sym">(</span><span class="src-var">$tableAlias</span><span class="src-sym">, </span><span class="src-var">$path</span><span class="src-sym">)</span></div></li>
|
|
<li><div class="src-line"><a name="a227"></a> <span class="src-sym">{</span></div></li>
|
|
<li><div class="src-line"><a name="a228"></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="a229"></a> <span class="src-var">$originalAlias </span>= <span class="src-sym">(</span><a href="http://www.php.net/count">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="a230"></a> </div></li>
|
|
<li><div class="src-line"><a name="a231"></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">$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-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a232"></a> </div></li>
|
|
<li><div class="src-line"><a name="a233"></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="a234"></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="a235"></a> </div></li>
|
|
<li><div class="src-line"><a name="a236"></a> <span class="src-var">$table </span>= <span class="src-id">null</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a237"></a> </div></li>
|
|
<li><div class="src-line"><a name="a238"></a> <span class="src-var">$currPath </span>= <span class="src-str">''</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a239"></a> </div></li>
|
|
<li><div class="src-line"><a name="a240"></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="a241"></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="a242"></a> </div></li>
|
|
<li><div class="src-line"><a name="a243"></a> <span class="src-var">$currPath </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="a244"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a245"></a> </div></li>
|
|
<li><div class="src-line"><a name="a246"></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">$component</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
|
<li><div class="src-line"><a name="a247"></a> <span class="src-comm">// get length of the previous path</span></div></li>
|
|
<li><div class="src-line"><a name="a248"></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">$currPath</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a249"></a> </div></li>
|
|
<li><div class="src-line"><a name="a250"></a> <span class="src-comm">// build the current component path</span></div></li>
|
|
<li><div class="src-line"><a name="a251"></a> <span class="src-var">$currPath </span>= <span class="src-sym">(</span><span class="src-var">$currPath</span><span class="src-sym">) </span>? <span class="src-var">$currPath </span>. <span class="src-str">'.' </span>. <span class="src-var">$component </span>: <span class="src-var">$component</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a252"></a> </div></li>
|
|
<li><div class="src-line"><a name="a253"></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="a254"></a> </div></li>
|
|
<li><div class="src-line"><a name="a255"></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="a256"></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">$currPath</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="a257"></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="a258"></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="a259"></a> <span class="src-var">$componentAlias </span>= <span class="src-var">$currPath</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a260"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a261"></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="a262"></a> <span class="src-var">$conn </span>= <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="a263"></a> <span class="src-sym">-></span><span class="src-id">getConnectionForComponent</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="a264"></a> </div></li>
|
|
<li><div class="src-line"><a name="a265"></a> <span class="src-var">$table </span>= <span class="src-var">$conn</span><span class="src-sym">-></span><span class="src-id">getTable</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="a266"></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="a267"></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="a268"></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">$component</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a269"></a> </div></li>
|
|
<li><div class="src-line"><a name="a270"></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">$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="a271"></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="a272"></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="a273"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a274"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Hydrate.html#methodaddTableAlias">addTableAlias</a><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><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a275"></a> </div></li>
|
|
<li><div class="src-line"><a name="a276"></a> <span class="src-var">$parent </span>= <span class="src-var">$currPath</span><span class="src-sym">;</span></div></li>
|
|
<li><div class="src-line"><a name="a277"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a278"></a> </div></li>
|
|
<li><div class="src-line"><a name="a279"></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="a280"></a> <span class="src-sym">}</span></div></li>
|
|
<li><div class="src-line"><a name="a281"></a> </div></li>
|
|
<li><div class="src-line"><a name="a282"></a><span class="src-sym">}</span></div></li>
|
|
</ol>
|
|
</span></div>
|
|
</div> |