{"id":9434,"date":"2018-10-26T10:01:06","date_gmt":"2018-10-26T13:01:06","guid":{"rendered":"http:\/\/www.fabriciolima.net\/?p=9434"},"modified":"2018-10-26T10:01:06","modified_gmt":"2018-10-26T13:01:06","slug":"azure-sql-database-monitorando-a-utilizacao-dos-indices","status":"publish","type":"post","link":"https:\/\/fabriciolima.net\/blog\/2018\/10\/26\/azure-sql-database-monitorando-a-utilizacao-dos-indices\/","title":{"rendered":"Azure SQL Database &#8211; Monitorando a Utiliza\u00e7\u00e3o dos \u00cdndices"},"content":{"rendered":"<p><img loading=\"lazy\" decoding=\"async\" class=\"wp-image-9425 aligncenter\" src=\"https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/09\/AzureSerie07.png\" alt=\"\" width=\"587\" height=\"349\" srcset=\"https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/09\/AzureSerie07.png 688w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/09\/AzureSerie07-300x178.png 300w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/09\/AzureSerie07-410x244.png 410w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/09\/AzureSerie07-100x59.png 100w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/09\/AzureSerie07-275x163.png 275w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/09\/AzureSerie07-20x12.png 20w\" sizes=\"auto, (max-width: 587px) 100vw, 587px\" \/><\/p>\n<p>&nbsp;<\/p>\n<p>Fala Pessoal,<\/p>\n<p>Continuando a s\u00e9rie de posts sobre\u00a0<strong>Azure SQL Database<\/strong>, dessa vez vamos criar uma rotina para que voc\u00ea possa monitorar a utiliza\u00e7\u00e3o dos \u00edndices no SQL do Azure.<\/p>\n<p>No Azure SQL Database voc\u00ea pode ativar uma op\u00e7\u00e3o para que o SQL te sugira ou exclua \u00edndices automaticamente. Ativando a op\u00e7\u00e3o de exclus\u00e3o autom\u00e1tica, o SQL no Azure ir\u00e1 excluir seu \u00edndice quando ele ficar mais de <strong>90 dias sem uso<\/strong> (seek ou scan) e com inserts\/updates\/deletes sendo realizados nesse \u00edndice.<\/p>\n<p>Refer\u00eancia:\u00a0<a href=\"https:\/\/sqlperformance.com\/2018\/04\/azure\/automatic-index-management-in-azure-sql-database\" target=\"_blank\" rel=\"noopener\">https:\/\/sqlperformance.com\/2018\/04\/azure\/automatic-index-management-in-azure-sql-database<\/a><\/p>\n<p>Caso n\u00e3o queira que o Azure exclua seus \u00edndices sem uso autom\u00e1ticamente <strong>OU<\/strong> caso queira fazer uma verifica\u00e7\u00e3o dupla antes dele excluir <strong>OU<\/strong> caso queira excluir um \u00edndice com menos tempo (1 ou 2 meses), voc\u00ea ter\u00e1 que fazer um monitoramento pr\u00f3prio para isso.<\/p>\n<p>Caso queira ter esse controle, vou compartilhar essa rotina com voc\u00eas.<\/p>\n<p>Ela cria algumas tabelas para armazenar as informa\u00e7\u00f5es, uma view para visualizar os dados e uma procedure de carga para inserir os registros nas tabelas.<\/p>\n<p>Segue o script completo no nosso <strong>Github<\/strong>:<\/p>\n<p><a href=\"https:\/\/github.com\/FabricioLimaSolucoesEmBD\/SQLScripts\/blob\/master\/AzureSQLDatabase\/Rotina%20para%20monitorar%20a%20utiliza%C3%A7%C3%A3o%20de%20%C3%8Dndices\" target=\"_blank\" rel=\"noopener\">Script rotina monitorar a utiliza\u00e7\u00e3o de indices<\/a><\/p>\n<p>Ap\u00f3s criada as tabelas, a view e a procedure do script acima, basta agendar a procedure <strong>stpCarga_Utilizacao_Indice<\/strong><em><strong>\u00a0<\/strong><\/em>no azure 1 vez por dia.<\/p>\n<p>Nesse post abaixo mostrei como voc\u00ea pode fazer esse agendamento:<\/p>\n<p><a href=\"https:\/\/www.fabriciolima.net\/blog\/2018\/08\/13\/azure-sql-database-como-criar-um-job-para-executar-uma-procedure\/\" target=\"_blank\" rel=\"noopener\">https:\/\/www.fabriciolima.net\/blog\/2018\/08\/13\/azure-sql-database-como-criar-um-job-para-executar-uma-procedure\/<\/a><\/p>\n<p>Ap\u00f3s executar uma vez a procedure de carga, j\u00e1 temos as informa\u00e7\u00f5es que precisamos conforme pode ser visto abaixo:<\/p>\n<pre class=\"lang:tsql decode:true\">select top 5 *\r\nfrom vwHistorico_Utilizacao_Indice\r\norder by User_Scans desc\r\n<\/pre>\n<p>Segue o resultado com os 5 \u00edndices que mais tem Scan no meu banco de teste.<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"wp-image-9523 aligncenter\" src=\"https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/10\/AzureSerie07_Scans.png\" alt=\"\" width=\"1197\" height=\"145\" srcset=\"https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/10\/AzureSerie07_Scans.png 1469w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/10\/AzureSerie07_Scans-300x36.png 300w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/10\/AzureSerie07_Scans-1024x124.png 1024w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/10\/AzureSerie07_Scans-768x93.png 768w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/10\/AzureSerie07_Scans-700x85.png 700w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/10\/AzureSerie07_Scans-410x50.png 410w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/10\/AzureSerie07_Scans-100x12.png 100w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/10\/AzureSerie07_Scans-275x33.png 275w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/10\/AzureSerie07_Scans-20x2.png 20w\" sizes=\"auto, (max-width: 1197px) 100vw, 1197px\" \/><\/p>\n<p>&nbsp;<\/p>\n<p>Pronto. Agora voc\u00ea consegue analisar como est\u00e1 a utiliza\u00e7\u00e3o dos seus \u00edndices e ver quais \u00edndices est\u00e3o sem uso por um determinando tempo para poder exclu\u00ed-los.<\/p>\n<p>Essa foi mais uma dica de como voc\u00ea pode fazer algo por suas bases no Azure SQL Database.<\/p>\n<p>At\u00e9 a pr\u00f3xima.<\/p>\n<p>Posts relacionados sobre o Azure SQL Database:<\/p>\n<ol>\n<li><a href=\"https:\/\/www.fabriciolima.net\/blog\/2018\/07\/10\/azure-sql-database-funcao-getdate-com-valor-errado-no-azure-e-isso-mesmo\/\" target=\"_blank\" rel=\"noopener\" data-wpel-link=\"internal\">Azure SQL Database \u2013 Fun\u00e7\u00e3o getdate() com valor errado no Azure. \u00c9 isso mesmo?<\/a><\/li>\n<li><a href=\"http:\/\/www.fabriciolima.net\/blog\/2018\/03\/17\/azure-sql-db-managed-instance-introducao\/\" target=\"_blank\" rel=\"noopener\" data-wpel-link=\"internal\">Azure SQL DB Managed Instance \u2013 Introdu\u00e7\u00e3o<\/a><\/li>\n<li><a href=\"http:\/\/www.fabriciolima.net\/blog\/2018\/07\/12\/azure-sql-database-como-fazer-um-join-entre-tabelas-de-bases-diferentes\/\" target=\"_blank\" rel=\"noopener\" data-wpel-link=\"internal\">Azure SQL Database \u2013 Como fazer um join entre tabelas de bases diferentes?<\/a><\/li>\n<li><a href=\"https:\/\/www.fabriciolima.net\/blog\/2018\/07\/17\/azure-sql-database-quanto-posso-usar-de-transaction-log-e-ilimitado\/\" target=\"_blank\" rel=\"noopener\" data-wpel-link=\"internal\">Azure SQL Database \u2013 Quanto posso usar de Transaction Log? \u00c9 ilimitado?<\/a><\/li>\n<li><a href=\"https:\/\/www.fabriciolima.net\/blog\/2018\/08\/13\/azure-sql-database-como-criar-um-job-para-executar-uma-procedure\/\" target=\"_blank\" rel=\"noopener\">Azure SQL Database \u2013 Como criar um Job para executar uma procedure?<\/a><\/li>\n<li><a href=\"https:\/\/www.fabriciolima.net\/blog\/2018\/10\/02\/azure-sql-database-monitorando-o-tamanho-das-tabelas\/\" target=\"_blank\" rel=\"noopener\" data-wpel-link=\"internal\">Azure SQL Database \u2013 Monitorando o Tamanho das Tabelas<\/a><\/li>\n<li><a href=\"https:\/\/www.fabriciolima.net\/blog\/2018\/10\/08\/azure-sql-database-monitorando-a-fragmentacao-dos-indices\/\" target=\"_blank\" rel=\"noopener\">Azure SQL Database \u2013 Monitorando a Fragmenta\u00e7\u00e3o dos \u00cdndices<\/a><\/li>\n<\/ol>\n<p><b>Gostou da dica?<\/b><\/p>\n<p>Curta, comente, compartilhe com os coleguinhas\u2026<\/p>\n<p>Assine meu canal no\u00a0<a class=\"external-link wpel-icon-left\" href=\"https:\/\/www.youtube.com\/channel\/UCeBRAO_LLrUdSrOXIywjzRA\" target=\"_blank\" rel=\"external noopener noreferrer nofollow\" data-wpel-link=\"external\">Youtube<\/a>\u00a0e curta minha\u00a0<a class=\"external-link wpel-icon-left\" href=\"https:\/\/www.facebook.com\/FabricioLimaSolucoesemBancodeDados\/\" target=\"_blank\" rel=\"external noopener noreferrer nofollow\" data-wpel-link=\"external\">P\u00e1gina no Facebook<\/a>\u00a0para receber Dicas de Leituras e Eventos sobre SQL Server.<\/p>\n<p>Abra\u00e7os,<\/p>\n<p>Fabr\u00edcio Lima<\/p>\n<p>Microsoft Data Platform MVP<\/p>\n<p>Consultor e Instrutor SQL Server<\/p>\n<p>Trabalha com SQL Server desde 2006<\/p>\n","protected":false},"excerpt":{"rendered":"<p>&nbsp; Fala Pessoal, Continuando a s\u00e9rie de posts sobre\u00a0Azure SQL Database, dessa vez vamos criar uma rotina para que voc\u00ea possa monitorar a utiliza\u00e7\u00e3o dos \u00edndices no SQL do Azure. No Azure SQL Database voc\u00ea pode ativar uma op\u00e7\u00e3o para que o SQL te sugira ou exclua \u00edndices automaticamente. Ativando a op\u00e7\u00e3o de exclus\u00e3o autom\u00e1tica, [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_exactmetrics_skip_tracking":false,"_exactmetrics_sitenote_active":false,"_exactmetrics_sitenote_note":"","_exactmetrics_sitenote_category":0,"footnotes":""},"categories":[1616,280],"tags":[],"class_list":["post-9434","post","type-post","status-publish","format-standard","hentry","category-azure-sql-database","category-virtual-pass-br"],"post_mailing_queue_ids":[],"_links":{"self":[{"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/posts\/9434","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/comments?post=9434"}],"version-history":[{"count":6,"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/posts\/9434\/revisions"}],"predecessor-version":[{"id":9570,"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/posts\/9434\/revisions\/9570"}],"wp:attachment":[{"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/media?parent=9434"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/categories?post=9434"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/tags?post=9434"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}