[pt] Uma dentre as muitas tarefas desempenhadas por DBAs
consiste em tentar
garantir que os tempos de respostas dos comandos
submetidos por usuários a um
grande SGBDR não excedam valores previamente acordados.
Esta dissertação
segue uma linha de estudos denominada auto-sintonia de
índices, que preconiza a
realização de ajustes automáticos na execução de consultas
SQL, visando reduzirlhes
tempos de resposta, a partir de alterações no conjunto de
índices: criação,
eliminação e recriação. Este trabalho teve como ponto de
partida a dissertação de
Marcos Salles [32], que seguiu a mesma linha, propondo um
mecanismo
automático de criação de índices. Esta dissertação estende
[32], primeiro
submetendo sua implementação a uma carga de trabalho
alternativa e depois
realizando eliminações e reconstruções de índices
automáticas, levando em
consideração níveis de preenchimento de páginas
alternativos. Também foram
realizados testes utilizando ferramentas comerciais,
Oracle 10g e SQL Server
2005, para avaliar quão eficaz comportou-se a
implementação proposta em [32].
Vale ressaltar que os testes realizados limitaram-se à
criação de índices, já que as
ferramentas não oferecem facilidades de reconstrução
automática. Diferentemente
dos trabalhos publicados nessa linha de estudos e das
ferramentas comerciais
disponíveis, foi criado um protótipo que não se limita a
sugerir novos índices;
também são eliminados os que deixaram de ser
interessantes, porém, antes ocorre
uma avaliação para verificar se a reconstrução não seria
mais adequada. Criou-se,
inclusive, uma heurística rudimentar que avalia um índice
a ser destruído e
recomenda sua reconstrução, caso atenda a determinados
requisitos. / [en] One of the most important tasks of Database Administrators
certainly is to
guarantee optimal response times to statements submitted
by users of big
RDBMS. Our dissertation deals with Index Self-tuning,
which means creating,
dropping or recreating indexes automatically, in order to
decrease SQL queries
durations. We start from Marcos Salles´ dissertation [32],
which proposed an
automatic way of creating indexes. We extend [32] in many
ways: first using a
different workload, TPC-H like. Second, following created
indexes inspecting its
usage. Finally, we have gotten to drop and, mostly,
recreate indexes using
different fillfactor in leaf pages. Also, we have
elaborated many tests using
commercial tools, Microsoft SQL Server 2005 and Oracle 10g
in order to ratify
[32] ideas. Unfortunatelly, we could not test automatic
dropping and recreating in
these tools, as long as they do not offer this kind of
functionalities. Unlike related
work and commercial tools, we have created a code
prototype that not only
suggests new indexes creations, but also drops and
recreates indexes using an own
heuristics. To validate our ideas we have used a TPC-C
like workload, but we had
to make some changes to increase updates and force
reindexing.
Identifer | oai:union.ndltd.org:puc-rio.br/oai:MAXWELL.puc-rio.br:9531 |
Date | 15 February 2007 |
Creators | EDUARDO MARIA TERRA MORELLI |
Contributors | SERGIO LIFSCHITZ |
Publisher | MAXWELL |
Source Sets | PUC Rio |
Language | Portuguese |
Detected Language | Portuguese |
Type | TEXTO |
Page generated in 0.0019 seconds