163 lines
39 KiB
HTML
163 lines
39 KiB
HTML
|
|
||
|
<div id="content">
|
||
|
<h1 align="center">Source for file Mssql.php</h1>
|
||
|
<p>Documentation is available at <a href="../Doctrine/_Doctrine---Sequence---Mssql.php.html">Mssql.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: Mssql.php 1934 2007-07-05 22:42:32Z 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_Sequence'</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_Sequence_Mssql</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">@author</span><span class="src-doc"> Konsta Vesterinen <kvesteri@cc.hut.fi></span></div></li>
|
||
|
<li><div class="src-line"><a name="a27"></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="a28"></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="a29"></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="a30"></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="a31"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@version</span><span class="src-doc"> $Revision: 1934 $</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_Sequence_Mssql.html">Doctrine_Sequence_Mssql</a> <span class="src-key">extends </span><a href="../Doctrine/Doctrine_Sequence.html">Doctrine_Sequence</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"> * Returns the next free id of a sequence</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-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">string </span><span class="src-doc-var">$seqName </span><span class="src-doc"> name of the sequence</span></div></li>
|
||
|
<li><div class="src-line"><a name="a39"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc-type">bool </span><span class="src-doc"> when true missing sequences are automatic created</span></div></li>
|
||
|
<li><div class="src-line"><a name="a40"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a41"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">integer </span><span class="src-doc"> next id in the given sequence</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-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Sequence_Mssql.html#methodnextId">nextId</a><span class="src-sym">(</span><span class="src-var">$seqName</span><span class="src-sym">, </span><span class="src-var">$onDemand </span>= <span class="src-id">true</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a44"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a45"></a> <span class="src-var">$sequenceName </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Connection_Module.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_Connection_Module.html#var$conn">conn</a><span class="src-sym">-></span><span class="src-id">formatter</span><span class="src-sym">-></span><span class="src-id">getSequenceName</span><span class="src-sym">(</span><span class="src-var">$seqName</span><span class="src-sym">)</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="a46"></a> <span class="src-var">$seqcolName </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Connection_Module.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_Connection_Module.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_SEQCOL_NAME</span><span class="src-sym">)</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="a47"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a48"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a49"></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_Sequence_Mssql.html#methodcheckSequence">checkSequence</a><span class="src-sym">(</span><span class="src-var">$sequenceName</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a50"></a> <span class="src-var">$query </span>= <span class="src-str">'SET IDENTITY_INSERT ' </span>. <span class="src-var">$sequenceName </span>. <span class="src-str">' OFF '</span></div></li>
|
||
|
<li><div class="src-line"><a name="a51"></a> . <span class="src-str">'INSERT INTO ' </span>. <span class="src-var">$sequenceName </span>. <span class="src-str">' DEFAULT VALUES'</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a52"></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="a53"></a> <span class="src-var">$query </span>= <span class="src-str">'INSERT INTO ' </span>. <span class="src-var">$sequenceName </span>. <span class="src-str">' (' </span>. <span class="src-var">$seqcolName </span>. <span class="src-str">') VALUES (0)'</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a54"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a55"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a56"></a> try <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a57"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a58"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Connection_Module.html#var$conn">conn</a><span class="src-sym">-></span><span class="src-id">exec</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="a59"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a60"></a> <span class="src-sym">} </span>catch<span class="src-sym">(</span><span class="src-id"><a href="../Doctrine/Doctrine_Connection_Exception.html">Doctrine_Connection_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="a61"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$onDemand </span>&& <span class="src-var">$e</span><span class="src-sym">-></span><span class="src-id">getPortableCode</span><span class="src-sym">(</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">ERR_NOSUCHTABLE</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a62"></a> <span class="src-comm">// Since we are creating the sequence on demand</span></div></li>
|
||
|
<li><div class="src-line"><a name="a63"></a> <span class="src-comm">// we know the first id = 1 so initialize the</span></div></li>
|
||
|
<li><div class="src-line"><a name="a64"></a> <span class="src-comm">// sequence at 2</span></div></li>
|
||
|
<li><div class="src-line"><a name="a65"></a> try <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a66"></a> <span class="src-var">$result </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Connection_Module.html#var$conn">conn</a><span class="src-sym">-></span><span class="src-id">export</span><span class="src-sym">-></span><span class="src-id">createSequence</span><span class="src-sym">(</span><span class="src-var">$seqName</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="a67"></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">$e</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a68"></a> throw <span class="src-key">new </span><span class="src-id"><a href="../Doctrine/Doctrine_Sequence_Exception.html">Doctrine_Sequence_Exception</a></span><span class="src-sym">(</span><span class="src-str">'on demand sequence ' </span>. <span class="src-var">$seqName </span>. <span class="src-str">' could not be created'</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-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a70"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a71"></a> /**</div></li>
|
||
|
<li><div class="src-line"><a name="a72"></a> * This could actually be a table that starts at 18.. oh well..</div></li>
|
||
|
<li><div class="src-line"><a name="a73"></a> * we will keep the fallback to return 1 in case we skip this.. which</div></li>
|
||
|
<li><div class="src-line"><a name="a74"></a> * should really not happen.. otherwise the returned values is biased.</div></li>
|
||
|
<li><div class="src-line"><a name="a75"></a> */</div></li>
|
||
|
<li><div class="src-line"><a name="a76"></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_Sequence_Mssql.html#methodcheckSequence">checkSequence</a><span class="src-sym">(</span><span class="src-var">$seqName</span><span class="src-sym">)) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a77"></a> <span class="src-key">return </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Sequence_Mssql.html#methodlastInsertId">lastInsertId</a><span class="src-sym">(</span><span class="src-var">$seqName</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-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-key">return </span><span class="src-num">1</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a81"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a82"></a> throw <span class="src-var">$e</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a83"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a84"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a85"></a> <span class="src-var">$value </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Sequence_Mssql.html#methodlastInsertId">lastInsertId</a><span class="src-sym">(</span><span class="src-var">$sequenceName</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a86"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a87"></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">$value</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-var">$query </span>= <span class="src-str">'DELETE FROM ' </span>. <span class="src-var">$sequenceName </span>. <span class="src-str">' WHERE ' </span>. <span class="src-var">$seqcolName </span>. <span class="src-str">' < ' </span>. <span class="src-var">$value</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a89"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a90"></a> try <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a91"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Connection_Module.html#var$conn">conn</a><span class="src-sym">-></span><span class="src-id">exec</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="a92"></a> <span class="src-sym">} </span>catch <span class="src-sym">(</span><span class="src-id"><a href="../Doctrine/Doctrine_Connection_Exception.html">Doctrine_Connection_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="a93"></a> throw <span class="src-key">new </span><span class="src-id"><a href="../Doctrine/Doctrine_Sequence_Exception.html">Doctrine_Sequence_Exception</a></span><span class="src-sym">(</span><span class="src-str">'Could not delete previous sequence from ' </span>. <span class="src-var">$sequenceName </span>. </div></li>
|
||
|
<li><div class="src-line"><a name="a94"></a> <span class="src-str">' at ' </span>. __FILE__ . <span class="src-str">' in ' </span>. __FUNCTION__ . <span class="src-str">' with the message: ' </span>.</div></li>
|
||
|
<li><div class="src-line"><a name="a95"></a> <span class="src-var">$e</span><span class="src-sym">-></span><span class="src-id">getMessage</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="a96"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a97"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a98"></a> <span class="src-key">return </span><span class="src-var">$value</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a99"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a100"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a101"></a><span class="src-doc"> * Checks if there's a sequence that exists.</span></div></li>
|
||
|
<li><div class="src-line"><a name="a102"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a103"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc"> </span><span class="src-doc-type">string </span><span class="src-doc-var">$seqName </span><span class="src-doc"> The sequence name to verify.</span></div></li>
|
||
|
<li><div class="src-line"><a name="a104"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">bool </span><span class="src-doc"> $tableExists The value if the table exists or not</span></div></li>
|
||
|
<li><div class="src-line"><a name="a105"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@access</span><span class="src-doc"> private</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-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Sequence_Mssql.html#methodcheckSequence">checkSequence</a><span class="src-sym">(</span><span class="src-var">$seqName</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a108"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a109"></a> <span class="src-var">$query </span>= <span class="src-str">'SELECT COUNT(1) FROM ' </span>. <span class="src-var">$seqName</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a110"></a> try <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a111"></a> <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Connection_Module.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">$query</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-sym">} </span>catch <span class="src-sym">(</span><span class="src-id"><a href="../Doctrine/Doctrine_Connection_Exception.html">Doctrine_Connection_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="a113"></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-id">getPortableCode</span><span class="src-sym">(</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">ERR_NOSUCHTABLE</span><span class="src-sym">) </span><span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a114"></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="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-key">return </span><span class="src-id">true</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a118"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a119"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a120"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a121"></a><span class="src-doc"> * Returns the autoincrement ID if supported or $id or fetches the current</span></div></li>
|
||
|
<li><div class="src-line"><a name="a122"></a><span class="src-doc"> * ID in a sequence called: $table.(empty($field) ? '' : '_'.$field)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a123"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a124"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc"> </span><span class="src-doc-type">string </span><span class="src-doc"> name of the table into which a new row was inserted</span></div></li>
|
||
|
<li><div class="src-line"><a name="a125"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@param </span><span class="src-doc"> </span><span class="src-doc-type">string </span><span class="src-doc"> name of the field into which a new row was inserted</span></div></li>
|
||
|
<li><div class="src-line"><a name="a126"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a127"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Sequence_Mssql.html#methodlastInsertId">lastInsertId</a><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">$field </span>= <span class="src-id">null</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a128"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a129"></a> <span class="src-var">$serverInfo </span>= <span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Connection_Module.html#var$conn">conn</a><span class="src-sym">-></span><span class="src-id">getServerVersion</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="a130"></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">$serverInfo</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a131"></a> && <span class="src-sym">! </span><a href="http://www.php.net/is_null">is_null</a><span class="src-sym">(</span><span class="src-var">$serverInfo</span><span class="src-sym">[</span><span class="src-str">'major'</span><span class="src-sym">]</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a132"></a> && <span class="src-var">$serverInfo</span><span class="src-sym">[</span><span class="src-str">'major'</span><span class="src-sym">] </span>>= <span class="src-num">8</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-var">$query </span>= <span class="src-str">'SELECT SCOPE_IDENTITY()'</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a135"></a> </div></li>
|
||
|
<li><div class="src-line"><a name="a136"></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="a137"></a> <span class="src-var">$query </span>= <span class="src-str">'SELECT @@IDENTITY'</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> </div></li>
|
||
|
<li><div class="src-line"><a name="a140"></a> <span class="src-key">return </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Connection_Module.html#var$conn">conn</a><span class="src-sym">-></span><span class="src-id">fetchOne</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="a141"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a142"></a> <span class="src-doc">/**</span></div></li>
|
||
|
<li><div class="src-line"><a name="a143"></a><span class="src-doc"> * Returns the current id of a sequence</span></div></li>
|
||
|
<li><div class="src-line"><a name="a144"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a145"></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">$seqName </span><span class="src-doc"> name of the sequence</span></div></li>
|
||
|
<li><div class="src-line"><a name="a146"></a><span class="src-doc"> *</span></div></li>
|
||
|
<li><div class="src-line"><a name="a147"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@return </span><span class="src-doc-type">integer </span><span class="src-doc"> current id in the given sequence</span></div></li>
|
||
|
<li><div class="src-line"><a name="a148"></a><span class="src-doc"> */</span></div></li>
|
||
|
<li><div class="src-line"><a name="a149"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../Doctrine/Doctrine_Sequence_Mssql.html#methodcurrId">currId</a><span class="src-sym">(</span><span class="src-var">$seqName</span><span class="src-sym">)</span></div></li>
|
||
|
<li><div class="src-line"><a name="a150"></a> <span class="src-sym">{</span></div></li>
|
||
|
<li><div class="src-line"><a name="a151"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-var">warnings</span><span class="src-sym">[</span><span class="src-sym">] </span>= <span class="src-str">'database does not support getting current</span></div></li>
|
||
|
<li><div class="src-line"><a name="a152"></a><span class="src-str"> sequence value, the sequence value was incremented'</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a153"></a> <span class="src-key">return </span><span class="src-var">$this</span><span class="src-sym">-></span><a href="../Doctrine/Doctrine_Sequence_Mssql.html#methodnextId">nextId</a><span class="src-sym">(</span><span class="src-var">$seqName</span><span class="src-sym">)</span><span class="src-sym">;</span></div></li>
|
||
|
<li><div class="src-line"><a name="a154"></a> <span class="src-sym">}</span></div></li>
|
||
|
<li><div class="src-line"><a name="a155"></a><span class="src-sym">}</span></div></li>
|
||
|
</ol>
|
||
|
</span></div>
|
||
|
</div>
|