(PHP 8 >= 8.4.0)
Pdo\Sqlite::createAggregate — Registra una función de agregación definida por el usuario para su uso en instrucciones SQL
$name
,$step
,$finalize
,$numArgs
= -1Este método es similar a Pdo\Sqlite::createFunction() excepto que registra funciones que pueden ser utilizadas para calcular un resultado agregado sobre el conjunto de filas de una consulta.
La principal diferencia entre este método y Pdo\Sqlite::createFunction() es que se necesitan dos funciones para manejar la agregación.
Utilizando este método, es posible reemplazar las funciones SQL nativas.
name
step
Esta función debe ser definida como sigue:
context
null
para la primera fila; en las filas siguientes, tendrá el valor
que fue previamente retornado por la función de retrollamada; debe utilizarse
esto para mantener el estado de la agregación.
rownumber
value
values
context
en la siguiente llamada a la función de retrollamada o
de finalización.
finalize
Esta función debe ser definida como sigue:
context
Contiene el valor de retorno de la última llamada a la función de retrollamada.
rowcount
Contiene el número de filas sobre las cuales se realizó la agregación.
numArgs
Ejemplo #1 Ejemplo de Pdo\Sqlite::createAggregate()
En este ejemplo, se creará una función de agregación personalizada llamada
max_length
que puede ser utilizada en las consultas SQL.
En este ejemplo, se creará una función de agregación llamada
max_length
que calculará la longitud del string más largo
en una de las columnas de la tabla.
Para cada fila, la función max_len_step
es llamada y
pasa un parámetro $context
.
El parámetro de contexto es como cualquier otra variable PHP y puede ser
definido para contener un array o incluso un object.
En este ejemplo, se utiliza para contener la longitud máxima que se ha visto hasta el momento;
si el $string tiene una longitud mayor que la longitud máxima actual,
se actualiza el contexto para contener esta nueva longitud máxima.
Después de que todas las filas han sido procesadas,
SQLite llama a la función max_len_finalize
para determinar
el resultado agregado.
Es posible realizar algún tipo de cálculo basado en los datos en $context
.
En este ejemplo básico, el resultado fue calculado a medida que la consulta progresaba,
por lo que el valor de contexto puede ser retornado directamente.
<?php
$data = [
'one',
'two',
'three',
'four',
'five',
'six',
'seven',
'eight',
'nine',
'ten',
];
$db = new Pdo\Sqlite('sqlite::memory:');
$db->exec("CREATE TABLE strings(a)");
$insert = $db->prepare('INSERT INTO strings VALUES (?)');
foreach ($data as $str) {
$insert->execute(array($str));
}
$insert = null;
function max_len_step($context, $row_number, $string)
{
if (strlen($string) > $context) {
$context = strlen($string);
}
return $context;
}
function max_len_finalize($context, $row_count)
{
return $context === null ? 0 : $context;
}
$db->createAggregate('max_len', 'max_len_step', 'max_len_finalize');
var_dump($db->query('SELECT max_len(a) from strings')->fetchAll());
?>
NO se recomienda almacenar una copia de los valores en el contexto y procesarlos al final, ya que se obligaría a SQLite a utilizar mucha memoria para procesar la consulta - imagine cuánta memoria se necesitaría si un millón de filas fueran almacenadas en memoria, cada una conteniendo un string de 32 bytes de longitud.