{"id":9415,"date":"2018-10-02T13:08:14","date_gmt":"2018-10-02T16:08:14","guid":{"rendered":"http:\/\/www.fabriciolima.net\/?p=9415"},"modified":"2018-10-02T13:23:30","modified_gmt":"2018-10-02T16:23:30","slug":"azure-sql-database-monitorando-o-tamanho-das-tabelas","status":"publish","type":"post","link":"https:\/\/fabriciolima.net\/blog\/2018\/10\/02\/azure-sql-database-monitorando-o-tamanho-das-tabelas\/","title":{"rendered":"Azure SQL Database &#8211; Monitorando o Tamanho das Tabelas"},"content":{"rendered":"<p><img loading=\"lazy\" decoding=\"async\" class=\" wp-image-9427 aligncenter\" src=\"https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/09\/AzureSerie05.png\" alt=\"\" width=\"565\" height=\"336\" srcset=\"https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/09\/AzureSerie05.png 689w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/09\/AzureSerie05-300x179.png 300w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/09\/AzureSerie05-410x244.png 410w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/09\/AzureSerie05-100x60.png 100w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/09\/AzureSerie05-275x164.png 275w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/09\/AzureSerie05-20x12.png 20w\" sizes=\"auto, (max-width: 565px) 100vw, 565px\" \/><\/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 o crescimento das suas tabelas no SQL do Azure.<\/p>\n<p>Quem administra um banco de dados importante, conhece as maiores tabelas, j\u00e1 que elas normalmente d\u00e3o mais trabalho na administra\u00e7\u00e3o e performance das queries.<\/p>\n<p>Dessa forma, saber o quanto essas tabelas crescem por &#8220;dia\/m\u00eas\/ano&#8221; pode te ajudar a prever alguns problemas de crescimento al\u00e9m do normal. Por exemplo, algum problema sist\u00eamico (isso j\u00e1 aconteceu algumas vezes comigo).<\/p>\n<p>No portal do Azure, s\u00f3 conseguimos monitorar o tamanho da base de dados por completo. N\u00e3o temos uma informa\u00e7\u00e3o detalhada de crescimento das tabelas.<\/p>\n<p>Para resolver isso, 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:<\/p>\n<p><a href=\"https:\/\/github.com\/FabricioLimaSolucoesEmBD\/SQLScripts\/blob\/master\/AzureSQLDatabase\/Rotina%20para%20monitorar%20o%20tamanho%20das%20tabelas\" target=\"_blank\" rel=\"noopener\">Script rotina para monitorar o tamanho de tabelas<\/a><\/p>\n<p>Ap\u00f3s criada as tabelas, a view e a procedure do script acima, basta agendar a procedure\u00a0<em><strong>stpCarga_Tamanhos_Tabelas\u00a0<\/strong><\/em>no azure <strong>1 vez por dia<\/strong>.<\/p>\n<p>No 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 vwTamanho_Tabela\r\norder by Nr_Tamanho_Total desc<\/pre>\n<p>Segue o resultado:<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" class=\"alignnone size-full wp-image-9507\" src=\"https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/10\/AzureSerie05_tamanho_Tabelas.png\" alt=\"\" width=\"1167\" height=\"149\" srcset=\"https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/10\/AzureSerie05_tamanho_Tabelas.png 1167w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/10\/AzureSerie05_tamanho_Tabelas-300x38.png 300w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/10\/AzureSerie05_tamanho_Tabelas-1024x131.png 1024w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/10\/AzureSerie05_tamanho_Tabelas-768x98.png 768w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/10\/AzureSerie05_tamanho_Tabelas-700x89.png 700w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/10\/AzureSerie05_tamanho_Tabelas-410x52.png 410w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/10\/AzureSerie05_tamanho_Tabelas-100x13.png 100w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/10\/AzureSerie05_tamanho_Tabelas-275x35.png 275w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/10\/AzureSerie05_tamanho_Tabelas-20x3.png 20w\" sizes=\"auto, (max-width: 1167px) 100vw, 1167px\" \/><\/p>\n<p>Rodando isso uma vez por dia, teremos uma foto com o tamanho da base por dia e conseguimos com algumas queries ver o crescimento por dia\/mes\/ano.<\/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<ul>\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<\/ul>\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>Fala Pessoal, Continuando a s\u00e9rie de posts sobre\u00a0Azure SQL Database, dessa vez vamos criar uma rotina para que voc\u00ea possa monitorar o crescimento das suas tabelas no SQL do Azure. Quem administra um banco de dados importante, conhece as maiores tabelas, j\u00e1 que elas normalmente d\u00e3o mais trabalho na administra\u00e7\u00e3o e performance das queries. Dessa [&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":"","jetpack_post_was_ever_published":false},"categories":[1616,280],"tags":[],"class_list":["post-9415","post","type-post","status-publish","format-standard","hentry","category-azure-sql-database","category-virtual-pass-br"],"jetpack_featured_media_url":"","jetpack-related-posts":[{"id":9431,"url":"https:\/\/fabriciolima.net\/blog\/2018\/10\/08\/azure-sql-database-monitorando-a-fragmentacao-dos-indices\/","url_meta":{"origin":9415,"position":0},"title":"Azure SQL Database &#8211; Monitorando a Fragmenta\u00e7\u00e3o dos \u00cdndices","author":"Fabr\u00edcio Lima","date":"8 de outubro de 2018","format":false,"excerpt":"\u00a0 Fala Pessoal, Continuando a s\u00e9rie de posts sobre\u00a0Azure SQL Database, dessa vez vamos criar uma rotina para monitorar a fragmenta\u00e7\u00e3o dos nossos \u00edndices. No SQL Azure Database, nossos \u00edndices continuam se fragmentando e o DBA\\DEV que administra essa base de dados continua com a miss\u00e3o de desfragmentar esses \u00edndices\u2026","rel":"","context":"Em &quot;Azure SQL Database&quot;","block_context":{"text":"Azure SQL Database","link":"https:\/\/fabriciolima.net\/blog\/category\/azure-sql-database\/"},"img":{"alt_text":"","src":"https:\/\/i0.wp.com\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/09\/AzureSerie06.png?resize=350%2C200&ssl=1","width":350,"height":200,"srcset":"https:\/\/i0.wp.com\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/09\/AzureSerie06.png?resize=350%2C200&ssl=1 1x, https:\/\/i0.wp.com\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/09\/AzureSerie06.png?resize=525%2C300&ssl=1 1.5x"},"classes":[]},{"id":9436,"url":"https:\/\/fabriciolima.net\/blog\/2018\/10\/29\/azure-sql-database-monitorando-a-utilizacao-de-recursos\/","url_meta":{"origin":9415,"position":1},"title":"Azure SQL Database &#8211; Monitorando a Utiliza\u00e7\u00e3o de Recursos","author":"Fabr\u00edcio Lima","date":"29 de outubro de 2018","format":false,"excerpt":"\u00a0 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 view sys.dm_db_resource_stats. Administramos um banco de dados no Azure onde o cliente n\u00e3o p\u00f4de nos liberar acesso ao portal, mas liberou acesso ao SQL via SSMS. Dessa\u2026","rel":"","context":"Em &quot;Azure SQL Database&quot;","block_context":{"text":"Azure SQL Database","link":"https:\/\/fabriciolima.net\/blog\/category\/azure-sql-database\/"},"img":{"alt_text":"","src":"https:\/\/i0.wp.com\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/09\/AzureSerie08.png?resize=350%2C200&ssl=1","width":350,"height":200,"srcset":"https:\/\/i0.wp.com\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/09\/AzureSerie08.png?resize=350%2C200&ssl=1 1x, https:\/\/i0.wp.com\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/09\/AzureSerie08.png?resize=525%2C300&ssl=1 1.5x"},"classes":[]},{"id":9434,"url":"https:\/\/fabriciolima.net\/blog\/2018\/10\/26\/azure-sql-database-monitorando-a-utilizacao-dos-indices\/","url_meta":{"origin":9415,"position":2},"title":"Azure SQL Database &#8211; Monitorando a Utiliza\u00e7\u00e3o dos \u00cdndices","author":"Fabr\u00edcio Lima","date":"26 de outubro de 2018","format":false,"excerpt":"\u00a0 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\u2026","rel":"","context":"Em &quot;Azure SQL Database&quot;","block_context":{"text":"Azure SQL Database","link":"https:\/\/fabriciolima.net\/blog\/category\/azure-sql-database\/"},"img":{"alt_text":"","src":"https:\/\/i0.wp.com\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/09\/AzureSerie07.png?resize=350%2C200&ssl=1","width":350,"height":200,"srcset":"https:\/\/i0.wp.com\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/09\/AzureSerie07.png?resize=350%2C200&ssl=1 1x, https:\/\/i0.wp.com\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/09\/AzureSerie07.png?resize=525%2C300&ssl=1 1.5x"},"classes":[]},{"id":9187,"url":"https:\/\/fabriciolima.net\/blog\/2018\/07\/17\/azure-sql-database-quanto-posso-usar-de-transaction-log-e-ilimitado\/","url_meta":{"origin":9415,"position":3},"title":"Azure SQL Database &#8211; Quanto posso usar de Transaction Log? \u00c9 ilimitado?","author":"Fabr\u00edcio Lima","date":"17 de julho de 2018","format":false,"excerpt":"Fala Pessoal, Continuando os posts sobre Azure SQL Database, dessa vez vamos falar sobre um erro de Log Full que consegui gerar em uma base no Azure. O Transaction Log de uma base no azure funciona da mesma forma que em uma inst\u00e2ncia On-Premise. Como no azure n\u00e3o conseguimos utilizar\u2026","rel":"","context":"Em &quot;Azure SQL Database&quot;","block_context":{"text":"Azure SQL Database","link":"https:\/\/fabriciolima.net\/blog\/category\/azure-sql-database\/"},"img":{"alt_text":"","src":"https:\/\/i0.wp.com\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/07\/AzureSQLDatabaseFotoE03.png?resize=350%2C200&ssl=1","width":350,"height":200,"srcset":"https:\/\/i0.wp.com\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/07\/AzureSQLDatabaseFotoE03.png?resize=350%2C200&ssl=1 1x, https:\/\/i0.wp.com\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/07\/AzureSQLDatabaseFotoE03.png?resize=525%2C300&ssl=1 1.5x"},"classes":[]},{"id":9285,"url":"https:\/\/fabriciolima.net\/blog\/2018\/08\/13\/azure-sql-database-como-criar-um-job-para-executar-uma-procedure\/","url_meta":{"origin":9415,"position":4},"title":"Azure SQL Database &#8211; Como criar um Job para executar uma procedure?","author":"Fabr\u00edcio Lima","date":"13 de agosto de 2018","format":false,"excerpt":"Fala Pessoal, Continuando a s\u00e9rie de posts sobre Azure SQL Database, dessa vez vou resolver um problema que muitos de voc\u00eas que j\u00e1 est\u00e3o trabalhando com o Azure SQL devem ter passado. Fabr\u00edcio, o Azure SQL Database n\u00e3o tem um Agent???? Como que vou rodar meus Jobs de Desfragmenta\u00e7\u00e3o de\u2026","rel":"","context":"Em &quot;Azure SQL Database&quot;","block_context":{"text":"Azure SQL Database","link":"https:\/\/fabriciolima.net\/blog\/category\/azure-sql-database\/"},"img":{"alt_text":"","src":"https:\/\/i0.wp.com\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/08\/AzureSerie04.png?resize=350%2C200&ssl=1","width":350,"height":200,"srcset":"https:\/\/i0.wp.com\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/08\/AzureSerie04.png?resize=350%2C200&ssl=1 1x, https:\/\/i0.wp.com\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/08\/AzureSerie04.png?resize=525%2C300&ssl=1 1.5x"},"classes":[]},{"id":9167,"url":"https:\/\/fabriciolima.net\/blog\/2018\/07\/12\/azure-sql-database-como-fazer-um-join-entre-tabelas-de-bases-diferentes\/","url_meta":{"origin":9415,"position":5},"title":"Azure SQL Database &#8211; Como fazer um join entre tabelas de bases diferentes?","author":"Fabr\u00edcio Lima","date":"12 de julho de 2018","format":false,"excerpt":"Fala Pessoal, Continuando a s\u00e9rie de posts sobre o Azure SQL Database, no meu dia a dia de Consultorias \u00e9 bem comum ver sistemas que utilizam mais de uma base de dados para realizar opera\u00e7\u00f5es. E no Azure SQL Database? Isso funciona? Vamos testar juntos? Criei duas bases (database01 e\u2026","rel":"","context":"Em &quot;Azure SQL Database&quot;","block_context":{"text":"Azure SQL Database","link":"https:\/\/fabriciolima.net\/blog\/category\/azure-sql-database\/"},"img":{"alt_text":"","src":"https:\/\/i0.wp.com\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/07\/AzureSQLDatabaseFotoE02.png?resize=350%2C200&ssl=1","width":350,"height":200,"srcset":"https:\/\/i0.wp.com\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/07\/AzureSQLDatabaseFotoE02.png?resize=350%2C200&ssl=1 1x, https:\/\/i0.wp.com\/fabriciolima.net\/blog\/wp-content\/uploads\/2018\/07\/AzureSQLDatabaseFotoE02.png?resize=525%2C300&ssl=1 1.5x"},"classes":[]}],"post_mailing_queue_ids":[],"_links":{"self":[{"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/posts\/9415","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=9415"}],"version-history":[{"count":9,"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/posts\/9415\/revisions"}],"predecessor-version":[{"id":9514,"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/posts\/9415\/revisions\/9514"}],"wp:attachment":[{"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/media?parent=9415"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/categories?post=9415"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/tags?post=9415"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}