2011-12-19 9 views
5

Tengo tablas LogItem y Log; Estoy escribiendo una consulta para obtener algunos datos de ambos. Hay miles de Logs y cada Log pueden tener hasta 125 LogItems¿Por qué la creación de este nuevo índice mejoró tanto el rendimiento cuando el índice existente incluía todas las columnas en el nuevo índice?

La consulta en cuestión se complica así que estoy saltando (si alguien piensa que es importante es probable que pueda publicarlo), pero cuando me encontré con SSMS estimado de consultas plan, me dijo que un nuevo índice no agrupado mejoraría el rendimiento hasta en un 100%.

Existing Index: Non-clustered 
Key Colums (LogItem): ParentLogID, DateModified, Name, DatabaseModified 

Query Plan Recommendation 
CREATE NONCLUSTERED INDEX [LogReportIndex] 
ON [dbo].[LogItem] ([ParentLogID],[DatabaseModified]) 

Sólo por diversión, he creado este nuevo índice y corrieron la consulta y para mi sorpresa, que ahora toma aproximadamente 1 segundo en mi consulta se ejecute, cuando antes era de 10 + segundos.

Supuse que mi índice existente cubriría esta nueva consulta, por lo que mi pregunta es ¿por qué la creación de un nuevo índice en las únicas columnas utilizadas en mi nueva consulta mejora el rendimiento? ¿Debo tener un índice para cada combinación única de columnas utilizadas en mis cláusulas where?

nota: No creo que esto se deba a que el SQL Server está almacenando en caché mis resultados, ejecuté la consulta unas 25-30 veces antes de crear el índice y tardó 10-15 segundos, después del índice ahora es constantemente ~ 1 o menos.

+0

Antes de crear el índice no agrupado adicional, ¿qué mostró el * plan de ejecución * para el uso del índice? –

+0

¿Cuál es el rendimiento mejorado en un 100%? – JeffO

+0

@Shark Buena pregunta, no estoy seguro. Esta es mi primera situación de depuración de rendimiento. Me aseguraré de agarrar eso en el futuro. Todo lo que dijo fue 'Falta el índice' y dijo qué campos. – Nate

Respuesta

6

El orden de las columnas en un índice es importante. Si el filtrado requiere la columna 1 y 4 del índice, el índice no ayudará. Solo es útil al filtrar por las primeras N columnas consecutivas.

Esto es porque index es un árbol. No puede seleccionar eficientemente todos los nodos del árbol donde column3 = something, ya que están dispersos por todos los demás, pertenecientes a diferentes valores de column1 y column2. Pero si conoce column1 y column2 también, ubicar la rama derecha en el árbol es pan comido.

+0

¿Sería entonces seguro suponer (en general) que necesito un índice por conjunto de cláusulas "where" que van a llegar a esa tabla? – Nate

+0

Una vez hice una aceleración masiva de la consulta de otra persona simplemente asegurándome de que utilizara el índice en el orden correcto. –

+0

@Nate En general, sí. Algunos 'where's pueden superponerse, por lo que puede tener un índice que cubra muy bien varios' where's; o puede ignorar alguna parte de una cláusula 'where' porque la indexación en una cierta columna no ayudará de todos modos (baja selectividad); pero en general, sí. – GSerg

2

El borde de avance de un índice es lo que importa.

Siempre y cuando su consulta esté "cubierta" por una punta de un índice, será eficiente. Los índices de base de datos se implementan típicamente como B-Trees y la estructura del B-Tree dicta que la búsqueda debe realizarse en un orden determinado, por lo que importa el orden de los campos en el índice compuesto.

Si tiene "agujeros", p. si busca en ParentLogID y DatabaseModified, pero solo tiene índice en {ParentLogID, DateModified, Name, DatabaseModified}, entonces solo la porción {ParentLogID} del índice se puede utilizar de manera eficiente.

(NOTA: Algunos DBMSes pueden utilizar la parte {DatabaseModified} través de "exploración con omisión", pero incluso si su DBMS hace que es mucho menos eficiente que el acceso índice normal).

+0

Así que si tengo 'Columnas (a, b, c, d, e, f)' y la mayoría de las consultas son '... DONDE A EN (...) Y B = 3' mi índice 'Index (a, b, c, d)' que es bueno, pero no ayuda si tengo '... WHERE A IN (...) AND D = 5' que es ¿Por qué mi nuevo índice que hice, 'Index (a, d)' mejoró tanto el rendimiento, ¿verdad? – Nate

+1

@Nate - correcto. Piense en ello como una guía telefónica. Si solo conoce el nombre de alguien, es imposible encontrarlo sin mirar todo el libro, ya que está organizado en Apellido, Nombre – JNK

Cuestiones relacionadas