Search This Blog

Monday, April 16, 2012

Si Shakespeare fuese un DBA – Cluster o NonCluster, esa es la cuestion

 

Durante el SQL Saturday #124, llevado a cabo en Bogota, Colombia y con mas de 200 asistentes, formule una pregunta para la que aplica cualquier tipo de respuesta…

Usar un indice tipo Cluster o usar un indice tipo NonCluster, la pregunta fue rapida, sin mayores detalles, la verdad esperaba tener silencio en el auditorio, pero contrario a lo que yo pensaba, me encontre con multiples respuestas, podriamos decir que la mitad reaccionaron inmediatamente y a una sola voz dijeron CLUSTER…

Durante la charla decidi explicar de la mejor manera posible lo que es un indice Cluster y lo que es un Indice NonCluster, de esta forma las opiniones cambiaron y al final todos llegamos a un concenso… Que sea Cluster o NonCluster dependen unica y exclusivamente de los requerimientos del negocio y de los requerimientos tecnicos, no hay uno mejor que el otro, ni uno sera mas rapido que el otro, todo DEPENDE…

Indice tipo Cluster

Consiste en informacion organizada fisicamente, un ejemplo claro y rapido de este tipo de indices, es el indice principal de un libro, alli todo esta organizado fisicamente y cuando accedemos al dato lo hacemos de forma directa, sin embargo tiene implicaciones de rendimiento importante al momento de escribir o actualizar datos en una tabla o en el libro, veamoslo de la siguiente manera, si tomas un libro y haces un DELETE (Arrancas un par de hojas), seguramente actualizar el indice no sera muy complejo, simplemente vamos a las primeras paginas, ubicamos las hojas que eliminamos y podriamos tacharlas alli directamente, ahora bien, al mismo libro decidimos agregarle un nuevo capitulo entre el 1 y el 2, llamemoslo capitulo 1.5, luego tomamos el libro, lo mandamos desbaratar y agregamos las paginas de nuestro nuevo capitulo, para poder agregar este capitulo al indice se hace entonces necesario eliminar algunas paginas del indice, editarlas, abrirle espacio al nuevo capitulo y reacomodar la informacion que ya se encontraba contenida en ese indice…

Comportamiento en el motor Ejemplo de indice tipo Cluster
image image

 

indice tipo noncluster

El indice tipo NonCluster se asemeja entonces al glosario de un libro, en este la informacion no se encuentra almacenada fisicamente y funciona bajo los mismos parametros de un apuntador, sabemos que informacion es y donde se encuentra, una vez identificamos esta informacion debemos ir hasta alli…

Una de las grandes ventajas del indice tipo NonCluster es la velocidad de escritura y actualizacion, sin embargo en la busqueda no es tan efectivo como el tipo Cluster.

Comportamiento en el motor

Ejemplo de indice tipo NonCluster

image image

Hasta la proxima

No comments:

LinkWithin

Related Posts Plugin for WordPress, Blogger...