<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/class.sqlite3.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'es',
  ),
  'this' => 
  array (
    0 => 'sqlite3.createaggregate.php',
    1 => 'SQLite3::createAggregate',
    2 => 'Registra una funci&oacute;n PHP para ser utilizada como funci&oacute;n de agregaci&oacute;n SQLite',
  ),
  'up' => 
  array (
    0 => 'class.sqlite3.php',
    1 => 'SQLite3',
  ),
  'prev' => 
  array (
    0 => 'sqlite3.construct.php',
    1 => 'SQLite3::__construct',
  ),
  'next' => 
  array (
    0 => 'sqlite3.createcollation.php',
    1 => 'SQLite3::createCollation',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'es',
    'path' => 'reference/sqlite3/sqlite3/createaggregate.xml',
  ),
  'history' => 
  array (
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="sqlite3.createaggregate" class="refentry">
 <div class="refnamediv">
  <h1 class="refname">SQLite3::createAggregate</h1>
  <p class="verinfo">(PHP 5 &gt;= 5.3.0, PHP 7, PHP 8)</p><p class="refpurpose"><span class="refname">SQLite3::createAggregate</span> &mdash; <span class="dc-title">Registra una función PHP para ser utilizada como función de agregación SQLite</span></p>

 </div>

 <div class="refsect1 description" id="refsect1-sqlite3.createaggregate-description">
  <h3 class="title">Descripción</h3>
  <div class="methodsynopsis dc-description">
   <span class="modifier">public</span> <span class="methodname"><strong>SQLite3::createAggregate</strong></span>(<br>&nbsp;&nbsp;&nbsp;&nbsp;<span class="methodparam"><span class="type"><a href="language.types.string.php" class="type string">string</a></span> <code class="parameter">$name</code></span>,<br>&nbsp;&nbsp;&nbsp;&nbsp;<span class="methodparam"><span class="type"><a href="language.types.callable.php" class="type callable">callable</a></span> <code class="parameter">$stepCallback</code></span>,<br>&nbsp;&nbsp;&nbsp;&nbsp;<span class="methodparam"><span class="type"><a href="language.types.callable.php" class="type callable">callable</a></span> <code class="parameter">$finalCallback</code></span>,<br>&nbsp;&nbsp;&nbsp;&nbsp;<span class="methodparam"><span class="type"><a href="language.types.integer.php" class="type int">int</a></span> <code class="parameter">$argCount</code><span class="initializer"> = -1</span></span><br>): <span class="type"><a href="language.types.boolean.php" class="type bool">bool</a></span></div>

  <p class="para rdfs-comment">
   Registra una función PHP o una función definida por el usuario para ser
   utilizada como función de agregación SQL, que será utilizada en las consultas
   SQL.
  </p>
 </div>


 <div class="refsect1 parameters" id="refsect1-sqlite3.createaggregate-parameters">
  <h3 class="title">Parámetros</h3>
  <p class="para">
   <dl>
    
     <dt><code class="parameter">name</code></dt>
     <dd>
      <p class="para">
       Nombre de la función de agregación SQL a crear o redefinir.
      </p>
     </dd>
    
    
     <dt><code class="parameter">stepCallback</code></dt>
     <dd>
      <p class="para">
       Función de retrollamada llamada para cada fila en el conjunto de resultados. Su
       función PHP debería acumular el resultado y almacenar su contexto de agregación.
      </p>
      <p class="para">
       Esta función debe ser definida como:
       <div class="methodsynopsis dc-description">
        <span class="methodname"><span class="replaceable">step</span></span>(<br>&nbsp;&nbsp;&nbsp;&nbsp;<span class="methodparam"><span class="type"><a href="language.types.mixed.php" class="type mixed">mixed</a></span> <code class="parameter">$context</code></span>,<br>&nbsp;&nbsp;&nbsp;&nbsp;<span class="methodparam"><span class="type"><a href="language.types.integer.php" class="type int">int</a></span> <code class="parameter">$rownumber</code></span>,<br>&nbsp;&nbsp;&nbsp;&nbsp;<span class="methodparam"><span class="type"><a href="language.types.mixed.php" class="type mixed">mixed</a></span> <code class="parameter">$value</code></span>,<br>&nbsp;&nbsp;&nbsp;&nbsp;<span class="methodparam"><span class="type"><a href="language.types.mixed.php" class="type mixed">mixed</a></span> <code class="parameter">...$values</code></span><br>): <span class="type"><a href="language.types.mixed.php" class="type mixed">mixed</a></span></div>

       <dl>
        
         <dt><code class="parameter">context</code></dt>
         <dd>
          <p class="para">
           <strong><code><a href="reserved.constants.php#constant.null">null</a></code></strong> para la primera fila; en las filas siguientes esto tendrá el valor
           que previamente fue retornado por la función step; debería utilizarse
           esto para mantener el estado de agregación.
          </p>
         </dd>
        
        
         <dt><code class="parameter">rownumber</code></dt>
         <dd>
          <p class="para">
           El número de fila actual.
          </p>
         </dd>
        
        
         <dt><code class="parameter">value</code></dt>
         <dd>
          <p class="para">
           El primer argumento a pasar al agregador.
          </p>
         </dd>
        
        
         <dt><code class="parameter">values</code></dt>
         <dd>
          <p class="para">
           Argumentos adicionales a pasar al agregador.
          </p>
         </dd>
        
       </dl>
       El valor retornado por esta función será utilizado como argumento
       <code class="parameter">context</code> durante la próxima llamada a una función
       de paso o final.
      </p>
     </dd>
    
    
     <dt><code class="parameter">finalCallback</code></dt>
     <dd>
      <p class="para">
       Función de retrollamada para agregar los &quot;pasos&quot; de datos de cada fila.
       Una vez que todas las filas han sido procesadas, la función será llamada,
       tomará los datos del contexto de agregación y retornará el resultado.
       La función de retrollamada debe retornar un tipo comprendido por SQLite
       (i.e. un <a href="language.types.intro.php" class="link">tipo escalar</a>).
      </p>
      <p class="para">
       Esta función debe ser definida como:
       <div class="methodsynopsis dc-description">
        <span class="methodname"><span class="replaceable">fini</span></span>(<span class="methodparam"><span class="type"><a href="language.types.mixed.php" class="type mixed">mixed</a></span> <code class="parameter">$context</code></span>, <span class="methodparam"><span class="type"><a href="language.types.integer.php" class="type int">int</a></span> <code class="parameter">$rownumber</code></span>): <span class="type"><a href="language.types.mixed.php" class="type mixed">mixed</a></span></div>

       <dl>
        
         <dt><code class="parameter">context</code></dt>
         <dd>
          <p class="para">
           Contiene el valor de retorno de la última llamada a la función step.
          </p>
         </dd>
        
        
         <dt><code class="parameter">rownumber</code></dt>
         <dd>
          <p class="para">
           Siempre <code class="literal">0</code>.
          </p>
         </dd>
        
       </dl>
       El valor de retorno de esta función será utilizado como valor de retorno para
       la agregación.
      </p>
     </dd>
    
    
     <dt><code class="parameter">argCount</code></dt>
     <dd>
      <p class="para">
       El número de argumentos tomados por la función de agregación SQL.
       Si este número es negativo, entonces la función de agregación SQL
       podrá tomar un número no definido de argumentos.
      </p>
     </dd>
    
   </dl>
  </p>

 </div>


 <div class="refsect1 returnvalues" id="refsect1-sqlite3.createaggregate-returnvalues">
  <h3 class="title">Valores devueltos</h3>
  <p class="para">
   Retorna <strong><code><a href="reserved.constants.php#constant.true">true</a></code></strong> si la creación del agregado ha tenido éxito,  o <strong><code><a href="reserved.constants.php#constant.false">false</a></code></strong> si ocurre un error.
  </p>
 </div>


 <div class="refsect1 examples" id="refsect1-sqlite3.createaggregate-examples">
  <h3 class="title">Ejemplos</h3>
  <p class="para">
   <div class="example" id="example-1">
    <p><strong>Ejemplo #1 Ejemplo de una función de agregación con max_length</strong></p>
    <div class="example-contents">
<div class="phpcode"><code><span style="color: #000000"><span style="color: #0000BB">&lt;?php<br />$data </span><span style="color: #007700">= array(<br />   </span><span style="color: #DD0000">'one'</span><span style="color: #007700">,<br />   </span><span style="color: #DD0000">'two'</span><span style="color: #007700">,<br />   </span><span style="color: #DD0000">'three'</span><span style="color: #007700">,<br />   </span><span style="color: #DD0000">'four'</span><span style="color: #007700">,<br />   </span><span style="color: #DD0000">'five'</span><span style="color: #007700">,<br />   </span><span style="color: #DD0000">'six'</span><span style="color: #007700">,<br />   </span><span style="color: #DD0000">'seven'</span><span style="color: #007700">,<br />   </span><span style="color: #DD0000">'eight'</span><span style="color: #007700">,<br />   </span><span style="color: #DD0000">'nine'</span><span style="color: #007700">,<br />   </span><span style="color: #DD0000">'ten'</span><span style="color: #007700">,<br />   );<br /></span><span style="color: #0000BB">$db </span><span style="color: #007700">= new </span><span style="color: #0000BB">SQLite3</span><span style="color: #007700">(</span><span style="color: #DD0000">':memory:'</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">$db</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">exec</span><span style="color: #007700">(</span><span style="color: #DD0000">"CREATE TABLE strings(a)"</span><span style="color: #007700">);<br /></span><span style="color: #0000BB">$insert </span><span style="color: #007700">= </span><span style="color: #0000BB">$db</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">prepare</span><span style="color: #007700">(</span><span style="color: #DD0000">'INSERT INTO strings VALUES (?)'</span><span style="color: #007700">);<br />foreach (</span><span style="color: #0000BB">$data </span><span style="color: #007700">as </span><span style="color: #0000BB">$str</span><span style="color: #007700">) {<br />    </span><span style="color: #0000BB">$insert</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">bindValue</span><span style="color: #007700">(</span><span style="color: #0000BB">1</span><span style="color: #007700">, </span><span style="color: #0000BB">$str</span><span style="color: #007700">);<br />    </span><span style="color: #0000BB">$insert</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">execute</span><span style="color: #007700">();<br />}<br /></span><span style="color: #0000BB">$insert </span><span style="color: #007700">= </span><span style="color: #0000BB">null</span><span style="color: #007700">;<br /><br />function </span><span style="color: #0000BB">max_len_step</span><span style="color: #007700">(</span><span style="color: #0000BB">$context</span><span style="color: #007700">, </span><span style="color: #0000BB">$rownumber</span><span style="color: #007700">, </span><span style="color: #0000BB">$string</span><span style="color: #007700">)<br />{<br />    if (</span><span style="color: #0000BB">strlen</span><span style="color: #007700">(</span><span style="color: #0000BB">$string</span><span style="color: #007700">) &gt; </span><span style="color: #0000BB">$context</span><span style="color: #007700">) {<br />        </span><span style="color: #0000BB">$context </span><span style="color: #007700">= </span><span style="color: #0000BB">strlen</span><span style="color: #007700">(</span><span style="color: #0000BB">$string</span><span style="color: #007700">);<br />    }<br />    return </span><span style="color: #0000BB">$context</span><span style="color: #007700">;<br />}<br /><br />function </span><span style="color: #0000BB">max_len_finalize</span><span style="color: #007700">(</span><span style="color: #0000BB">$context</span><span style="color: #007700">, </span><span style="color: #0000BB">$rownumber</span><span style="color: #007700">)<br />{<br />    return </span><span style="color: #0000BB">$context </span><span style="color: #007700">=== </span><span style="color: #0000BB">null </span><span style="color: #007700">? </span><span style="color: #0000BB">0 </span><span style="color: #007700">: </span><span style="color: #0000BB">$context</span><span style="color: #007700">;<br />}<br /><br /></span><span style="color: #0000BB">$db</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">createAggregate</span><span style="color: #007700">(</span><span style="color: #DD0000">'max_len'</span><span style="color: #007700">, </span><span style="color: #DD0000">'max_len_step'</span><span style="color: #007700">, </span><span style="color: #DD0000">'max_len_finalize'</span><span style="color: #007700">);<br /><br /></span><span style="color: #0000BB">var_dump</span><span style="color: #007700">(</span><span style="color: #0000BB">$db</span><span style="color: #007700">-&gt;</span><span style="color: #0000BB">querySingle</span><span style="color: #007700">(</span><span style="color: #DD0000">'SELECT max_len(a) from strings'</span><span style="color: #007700">));<br /></span><span style="color: #0000BB">?&gt;</span></span></code></div>
    </div>

    <div class="example-contents"><p>El ejemplo anterior mostrará:</p></div>
    <div class="example-contents screen">
<div class="examplescode"><pre class="examplescode">int(5)</pre>
</div>
    </div>
   </div>
  </p>
  <p class="para">
   En este ejemplo, se crea una función agregativa que calculará la
   longitud de la cadena de caracteres más larga en una de las columnas de la
   tabla. Para cada fila, la función <code class="literal">max_len_step</code> es
   llamada y el parámetro <code class="literal">$context</code> es pasado. El
   parámetro de contexto es como cualquier otra variable PHP y debe ser fijado para
   contener un array o incluso, un objeto. En este ejemplo,
   se utiliza para contener la longitud máxima que se ha visto hasta el momento; si el
   parámetro <code class="literal">$string</code> tiene una longitud mayor que la actual, se
   actualiza el contexto para contener esta nueva longitud máxima.
  </p>
  <p class="para">
   Una vez que todas las filas han sido procesadas, SQLite llama a la función
   <code class="literal">max_len_finalize</code> para determinar el resultado agregativo.
   Aquí, se podrían realizar cálculos basados en los datos encontrados
   en <code class="literal">$context</code>. En nuestro ejemplo simple, hemos
   calculado el resultado como si la consulta estuviera progresando, aunque simplemente
   necesitamos retornar el valor de contexto.
  </p>
  <div class="tip"><strong class="tip">Sugerencia</strong>
   <p class="para">
    No se RECOMIENDA registrar una copia de los valores en el contexto
    para finalmente procesarlos. En este caso, SQLite utilizaría mucha memoria
    para procesar la consulta - imagine la cantidad de memoria necesaria
    si un millón de filas fueran registradas en memoria, sabiendo que cada fila
    contiene una cadena de caracteres (32 bytes por cadena).
   </p>
  </div>
  <div class="tip"><strong class="tip">Sugerencia</strong>
   <p class="para">
    Puede utilizarse <span class="methodname"><strong>SQLite3::createAggregate()</strong></span> para sobrescribir las
    funciones nativas de SQLite.
   </p>
  </div>
 </div>


</div><?php manual_footer($setup); ?>