Las tablas particionadas son un feature el cual nos permite particionar una tabla siguiendo un determinado criterio.
Por ejemplo imaginemos una tabla de facturas, en donde tenemos el detalle de nuestra facturación a lo largo de 5 años, 2005, 2006… 2009, si quisiéramos hacer:
SELECT SUM(precio) FROM facturación WHERE ano = 2006;
En este ejempo se deberia recorrer toda la table (imaginemos que hablamos de 30 millones de registros en total,es mucho no?), por este motivo un criterio posible para particionar la tabla seria por el año de efectuada la fatura
Luego de esta pequeña intro, veamos algunos ejemplos:
1-) Creación de tablas particionadas
CREATE TABLE facturacion (id number, precio number(10,2), ano (number 4))
PARTITION BY RANGE (ano)
PARTITION p1 VALUES LESS THAN (2007) TABLESPACE tab1,
PARTITION p2 VALUES LESS THAN (2009) TABLESPACE tab2,
PARTITION p3 VALUES LESS THAN (MAXVALUE) TABLESPACE tab3;
Con este simple script creamos una tabla particionada con 3 particiones teniendo como criterio de separación el campo “ano”, todas estas particiones las estamos almacenando en tablespaces separados (aunque esto no es necesario es aconsejable)
Existen distintos tipos de “partition” pero lo vamos a dejar para otro post ya que la intención de este es que sea sencillo como para empezar a comprender el tema.
2-) Cambiar una tabla particionada
Podemos agregar una partición adicional a nuestra tabla particionada, para esto debemos utilizar la clausula SPLIT PARTITION
Por ejemplo podemos agregar una partición a nuetra tabla de ejemplo:
ALTER TABLE facturacion ADD PARTITION p4 VALUES LESS THAR (2010);
Cabe aclarar que podríamos determinar el tablespaces que almacenará la nueva partición.
3-) Eliminar particiones
ALTER TABLE facturacion DROP PARTITION p2;
En este caso si existiese un indice deberiamos hacerle un REBUILD.
Tenemos otra forma para no rebuildear el índice y es:
ALTER TABLE facturacion DROP PARTITION p2 UPDATE GLOBAL INDEX;
4-) Unir particiones
Si quisieramos unir 2 o mas particiones debemos hacer lo siguiente
ALTER TABLE facturacion MERGE PARTITION p2 AND p3 INTO PARTITION pnueva;
5-) Modificar particiones
Para agregar o quitar valores de una particion utilizamos la clausula
MODIFY PARTITION …. ADD/DROP VALUES
ALTER TABLE nacionalidad MODIFY PARTITION sud ADD VALUES (‘ARGENTINA’, ‘PERU’);
6-) Separar particiones
Podemos separar una particion en una o mas particiones de la siguiente manera:
(PARTITION p11 VALUES LESS THAN (2006)
(PARTITION p11 VALUES LESS THAN (MINVALUE));
7-) Truncar una partición
ALTER TALE facturacion TRUNCATE PARTITION p11;
Espero les haya servido.
Saludos!
Gondalf.