{"id":167,"date":"2008-11-15T12:40:57","date_gmt":"2008-11-15T15:40:57","guid":{"rendered":"https:\/\/devkico.itexto.com.br\/?p=167"},"modified":"2008-11-15T12:42:21","modified_gmt":"2008-11-15T15:42:21","slug":"jdbc-maldito-access-como-resolver-o-problema-nao-e-possivel-abrir-mais-tabelas-cant-open-more-tables","status":"publish","type":"post","link":"https:\/\/devkico.itexto.com.br\/?p=167","title":{"rendered":"JDBC: Maldito Access: como resolver o problema &#8220;n\u00e3o \u00e9 poss\u00edvel abrir mais tabelas (can&#8217;t open more tables)&#8221;"},"content":{"rendered":"<p><a href=\"https:\/\/devkico.itexto.com.br\/wp-content\/uploads\/2008\/11\/access97.png\"><img loading=\"lazy\" decoding=\"async\" class=\"size-full wp-image-168 alignnone\" title=\"access97\" src=\"https:\/\/devkico.itexto.com.br\/wp-content\/uploads\/2008\/11\/access97.png\" alt=\"\" width=\"400\" height=\"247\" srcset=\"https:\/\/devkico.itexto.com.br\/wp-content\/uploads\/2008\/11\/access97.png 400w, https:\/\/devkico.itexto.com.br\/wp-content\/uploads\/2008\/11\/access97-300x185.png 300w\" sizes=\"(max-width: 400px) 100vw, 400px\" \/><\/a><\/p>\n<p>Ent\u00e3o aconteceu com voc\u00ea: um belo dia teve de programar em Java acessando o maldito &#8220;banco de dados&#8221; Access&#8230; Seu c\u00f3digo est\u00e1 escrito corretamente e a aplica\u00e7\u00e3o \u00e9 iniciada. No in\u00edcio, tudo vai bem, voc\u00ea at\u00e9 se surpreeende com o fato de estar funcionando, at\u00e9 que, sem mais nem menos, come\u00e7am a surgir excess\u00f5es com as mensagens &#8220;N\u00e3o \u00e9 poss\u00edvel abrir mais tabelas&#8221; ou, em ingl\u00eas: &#8220;can&#8217;t open more tables&#8221;.<\/p>\n<p>\u00c9 um daqueles momentos nos quais voc\u00ea realmente pensa em matar o infeliz que optou por usar este &#8220;banco de dados&#8221;. Mesmo consultas que s\u00f3 envolvam uma tabela come\u00e7am a disparar esta excess\u00e3o e, mesmo que voc\u00ea feche todas as suas inst\u00e2ncias das classes ResultSet e PreparedStatement, ou mesmo suas conex\u00f5es com o banco, o erro persiste.<\/p>\n<p>A impress\u00e3o que temos \u00e9 que s\u00f3 \u00e9 poss\u00edvel trabalhar com este (argh) &#8220;banco de dados&#8221; se estivermos programando em VB ou VBA. Na pr\u00e1tica, esta \u00e9 a realidade, e,\u00a0 como irei mostrar a seguir, a solu\u00e7\u00e3o para este problema n\u00e3o poderia ser mais tosca. Todo o problema est\u00e1 no driver de acesso ODBC ao Access.<\/p>\n<p>Este driver, desenvolvido pela Microsoft (l\u00f3gico) suporte apenas 1024 consultas a um banco Access. Sendo assim, voc\u00ea precisa fechar todas as consultas ou statements que venha a executar com rela\u00e7\u00e3o a este banco. O mais interessante \u00e9: n\u00e3o basta chamar o m\u00e9todo close() das classes ResultSet e PreparedStatment e, para minha surpresa, tamb\u00e9m n\u00e3o \u00e9 necess\u00e1rio ficar criando e fechando sucessivas conex\u00f5es com o &#8220;banco&#8221; Access.<\/p>\n<p>Basta seguir o seguinte procedimento:<\/p>\n<ol>\n<li>Conecte-se ao &#8220;banco&#8221;. Voc\u00ea poder\u00e1 reaproveitar sua conex\u00e3o com o arquivo do Access. O problema n\u00e3o \u00e9 com ela (b\u00f4nus para voc\u00ea, pois n\u00e3o precisar\u00e1 mais sacrificar sua performance abrindo e fechando conex\u00f5es a cada consulta).<\/li>\n<li>Instancie o seu objeto ResultSet ou PreparedStatement, e em seguida fa\u00e7a o que tem de fazer.<\/li>\n<li>Finalizada a execu\u00e7\u00e3o, chame o m\u00e9todo close da sua classe.<\/li>\n<li>Como se n\u00e3o bastasse chamar o m\u00e9todo close(), defina a sua inst\u00e2ncia do objeto como null.<\/li>\n<\/ol>\n<p>De tempos em tempos (vamos supor, de 20 em 20 execu\u00e7\u00f5es, por exemplo) chame o garbage colector do Java para limpar as vari\u00e1veis n\u00e3o utilizadas. Pasme: somente assim as consultas s\u00e3o fechadas com o &#8220;banco e dados&#8221; em quest\u00e3o.<\/p>\n<p>\u00c9 uma gambiarra? Com certeza. A performance vai ser prejudicada? Pode apostar. \u00c9 uma solu\u00e7\u00e3o elegante? Nem um pouco. Mas por outro lado, voc\u00ea est\u00e1 usando uma das piores op\u00e7\u00f5es que existem. S\u00f3 o fato de estar usando Access j\u00e1 \u00e9 uma gambiarra, sendo assim, infelizmente, sofra as consequ\u00eancias.<\/p>\n<p>Descobri esta solu\u00e7\u00e3o enquanto desenvolvia uma &#8220;aplica\u00e7\u00e3o&#8221; que precisava do Access (no meu caso, o 97) no Netbeans. Ao execut\u00e1-la no ambiente da IDE, o erro n\u00e3o aparecia. Ao execut\u00e1-la independentemente, o erro aparecia (e sempre). Constatei ent\u00e3o que o Netbeans chama o garbage colector constantemente, ao passo que minha aplica\u00e7\u00e3o n\u00e3o. Visto que j\u00e1 sabia do bug do driver, somei 2 + 2 e resolvi tentar esta solu\u00e7\u00e3o. Para minha surpresa, funcionou melhor que o esperado. A perda de performance n\u00e3o foi t\u00e3o grande e, para minha surpresa, a excess\u00e3o simplesmente desapareceu.<\/p>\n<p>Tudo bem: o principal problema com o Access foi resolvido. No entanto, fa\u00e7a um favor a voc\u00ea e aos futuros programadores que, por desventura venham a dar manuten\u00e7\u00e3o em seus sistemas: ESQUE\u00c7A O ACCESS!<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Ent\u00e3o aconteceu com voc\u00ea: um belo dia teve de programar em Java acessando o maldito &#8220;banco de dados&#8221; Access&#8230; Seu c\u00f3digo est\u00e1 escrito corretamente e a aplica\u00e7\u00e3o \u00e9 iniciada. No in\u00edcio, tudo vai bem, voc\u00ea at\u00e9 se surpreeende com o fato de estar funcionando, at\u00e9 que, sem mais nem menos, come\u00e7am a surgir excess\u00f5es com [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_coblocks_attr":"","_coblocks_dimensions":"","_coblocks_responsive_height":"","_coblocks_accordion_ie_support":"","site-sidebar-layout":"default","site-content-layout":"","ast-site-content-layout":"","site-content-style":"default","site-sidebar-style":"default","ast-global-header-display":"","ast-banner-title-visibility":"","ast-main-header-display":"","ast-hfb-above-header-display":"","ast-hfb-below-header-display":"","ast-hfb-mobile-header-display":"","site-post-title":"","ast-breadcrumbs-content":"","ast-featured-img":"","footer-sml-layout":"","theme-transparent-header-meta":"","adv-header-id-meta":"","stick-header-meta":"","header-above-stick-meta":"","header-main-stick-meta":"","header-below-stick-meta":"","astra-migrate-meta-layouts":"default","ast-page-background-enabled":"default","ast-page-background-meta":{"desktop":{"background-color":"var(--ast-global-color-4)","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-gradient":""},"tablet":{"background-color":"","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-gradient":""},"mobile":{"background-color":"","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-gradient":""}},"ast-content-background-meta":{"desktop":{"background-color":"var(--ast-global-color-5)","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-gradient":""},"tablet":{"background-color":"var(--ast-global-color-5)","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-gradient":""},"mobile":{"background-color":"var(--ast-global-color-5)","background-image":"","background-repeat":"repeat","background-position":"center center","background-size":"auto","background-attachment":"scroll","background-type":"","background-media":"","overlay-type":"","overlay-color":"","overlay-gradient":""}},"jetpack_post_was_ever_published":false,"_jetpack_newsletter_access":"","_jetpack_dont_email_post_to_subs":false,"_jetpack_newsletter_tier_id":0,"_jetpack_memberships_contains_paywalled_content":false,"_jetpack_memberships_contains_paid_content":false,"footnotes":""},"categories":[23,6,24],"tags":[69],"class_list":["post-167","post","type-post","status-publish","format-standard","hentry","category-access","category-java","category-jdbc","tag-jdbc"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v22.8 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>JDBC: Maldito Access: como resolver o problema &quot;n\u00e3o \u00e9 poss\u00edvel abrir mais tabelas (can&#039;t open more tables)&quot; - \/dev\/Kico<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/devkico.itexto.com.br\/?p=167\" \/>\n<meta property=\"og:locale\" content=\"pt_BR\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"JDBC: Maldito Access: como resolver o problema &quot;n\u00e3o \u00e9 poss\u00edvel abrir mais tabelas (can&#039;t open more tables)&quot; - \/dev\/Kico\" \/>\n<meta property=\"og:description\" content=\"Ent\u00e3o aconteceu com voc\u00ea: um belo dia teve de programar em Java acessando o maldito &#8220;banco de dados&#8221; Access&#8230; Seu c\u00f3digo est\u00e1 escrito corretamente e a aplica\u00e7\u00e3o \u00e9 iniciada. No in\u00edcio, tudo vai bem, voc\u00ea at\u00e9 se surpreeende com o fato de estar funcionando, at\u00e9 que, sem mais nem menos, come\u00e7am a surgir excess\u00f5es com [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/devkico.itexto.com.br\/?p=167\" \/>\n<meta property=\"og:site_name\" content=\"\/dev\/Kico\" \/>\n<meta property=\"article:published_time\" content=\"2008-11-15T15:40:57+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2008-11-15T15:42:21+00:00\" \/>\n<meta property=\"og:image\" content=\"http:\/\/www.itexto.net\/devkico\/wp-content\/uploads\/2008\/11\/access97.png\" \/>\n<meta name=\"author\" content=\"Kico (Henrique Lobo Weissmann)\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:creator\" content=\"@loboweissmann\" \/>\n<meta name=\"twitter:label1\" content=\"Escrito por\" \/>\n\t<meta name=\"twitter:data1\" content=\"Kico (Henrique Lobo Weissmann)\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. tempo de leitura\" \/>\n\t<meta name=\"twitter:data2\" content=\"3 minutos\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/devkico.itexto.com.br\/?p=167\",\"url\":\"https:\/\/devkico.itexto.com.br\/?p=167\",\"name\":\"JDBC: Maldito Access: como resolver o problema \\\"n\u00e3o \u00e9 poss\u00edvel abrir mais tabelas (can't open more tables)\\\" - \/dev\/Kico\",\"isPartOf\":{\"@id\":\"https:\/\/devkico.itexto.com.br\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\/\/devkico.itexto.com.br\/?p=167#primaryimage\"},\"image\":{\"@id\":\"https:\/\/devkico.itexto.com.br\/?p=167#primaryimage\"},\"thumbnailUrl\":\"https:\/\/devkico.itexto.com.br\/wp-content\/uploads\/2008\/11\/access97.png\",\"datePublished\":\"2008-11-15T15:40:57+00:00\",\"dateModified\":\"2008-11-15T15:42:21+00:00\",\"author\":{\"@id\":\"https:\/\/devkico.itexto.com.br\/#\/schema\/person\/502ab8892631bb005d6da2269fe5a3a7\"},\"breadcrumb\":{\"@id\":\"https:\/\/devkico.itexto.com.br\/?p=167#breadcrumb\"},\"inLanguage\":\"pt-BR\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/devkico.itexto.com.br\/?p=167\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-BR\",\"@id\":\"https:\/\/devkico.itexto.com.br\/?p=167#primaryimage\",\"url\":\"https:\/\/devkico.itexto.com.br\/wp-content\/uploads\/2008\/11\/access97.png\",\"contentUrl\":\"https:\/\/devkico.itexto.com.br\/wp-content\/uploads\/2008\/11\/access97.png\"},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/devkico.itexto.com.br\/?p=167#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/devkico.itexto.com.br\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"JDBC: Maldito Access: como resolver o problema &#8220;n\u00e3o \u00e9 poss\u00edvel abrir mais tabelas (can&#8217;t open more tables)&#8221;\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/devkico.itexto.com.br\/#website\",\"url\":\"https:\/\/devkico.itexto.com.br\/\",\"name\":\"\/dev\/Kico\",\"description\":\"Desenvolvendo software\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/devkico.itexto.com.br\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"pt-BR\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/devkico.itexto.com.br\/#\/schema\/person\/502ab8892631bb005d6da2269fe5a3a7\",\"name\":\"Kico (Henrique Lobo Weissmann)\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-BR\",\"@id\":\"https:\/\/devkico.itexto.com.br\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/dd6973d86a689bc63122b2e603f25be3?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/dd6973d86a689bc63122b2e603f25be3?s=96&d=mm&r=g\",\"caption\":\"Kico (Henrique Lobo Weissmann)\"},\"sameAs\":[\"https:\/\/x.com\/loboweissmann\"],\"url\":\"https:\/\/devkico.itexto.com.br\/?author=1\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"JDBC: Maldito Access: como resolver o problema \"n\u00e3o \u00e9 poss\u00edvel abrir mais tabelas (can't open more tables)\" - \/dev\/Kico","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/devkico.itexto.com.br\/?p=167","og_locale":"pt_BR","og_type":"article","og_title":"JDBC: Maldito Access: como resolver o problema \"n\u00e3o \u00e9 poss\u00edvel abrir mais tabelas (can't open more tables)\" - \/dev\/Kico","og_description":"Ent\u00e3o aconteceu com voc\u00ea: um belo dia teve de programar em Java acessando o maldito &#8220;banco de dados&#8221; Access&#8230; Seu c\u00f3digo est\u00e1 escrito corretamente e a aplica\u00e7\u00e3o \u00e9 iniciada. No in\u00edcio, tudo vai bem, voc\u00ea at\u00e9 se surpreeende com o fato de estar funcionando, at\u00e9 que, sem mais nem menos, come\u00e7am a surgir excess\u00f5es com [&hellip;]","og_url":"https:\/\/devkico.itexto.com.br\/?p=167","og_site_name":"\/dev\/Kico","article_published_time":"2008-11-15T15:40:57+00:00","article_modified_time":"2008-11-15T15:42:21+00:00","og_image":[{"url":"http:\/\/www.itexto.net\/devkico\/wp-content\/uploads\/2008\/11\/access97.png"}],"author":"Kico (Henrique Lobo Weissmann)","twitter_card":"summary_large_image","twitter_creator":"@loboweissmann","twitter_misc":{"Escrito por":"Kico (Henrique Lobo Weissmann)","Est. tempo de leitura":"3 minutos"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/devkico.itexto.com.br\/?p=167","url":"https:\/\/devkico.itexto.com.br\/?p=167","name":"JDBC: Maldito Access: como resolver o problema \"n\u00e3o \u00e9 poss\u00edvel abrir mais tabelas (can't open more tables)\" - \/dev\/Kico","isPartOf":{"@id":"https:\/\/devkico.itexto.com.br\/#website"},"primaryImageOfPage":{"@id":"https:\/\/devkico.itexto.com.br\/?p=167#primaryimage"},"image":{"@id":"https:\/\/devkico.itexto.com.br\/?p=167#primaryimage"},"thumbnailUrl":"https:\/\/devkico.itexto.com.br\/wp-content\/uploads\/2008\/11\/access97.png","datePublished":"2008-11-15T15:40:57+00:00","dateModified":"2008-11-15T15:42:21+00:00","author":{"@id":"https:\/\/devkico.itexto.com.br\/#\/schema\/person\/502ab8892631bb005d6da2269fe5a3a7"},"breadcrumb":{"@id":"https:\/\/devkico.itexto.com.br\/?p=167#breadcrumb"},"inLanguage":"pt-BR","potentialAction":[{"@type":"ReadAction","target":["https:\/\/devkico.itexto.com.br\/?p=167"]}]},{"@type":"ImageObject","inLanguage":"pt-BR","@id":"https:\/\/devkico.itexto.com.br\/?p=167#primaryimage","url":"https:\/\/devkico.itexto.com.br\/wp-content\/uploads\/2008\/11\/access97.png","contentUrl":"https:\/\/devkico.itexto.com.br\/wp-content\/uploads\/2008\/11\/access97.png"},{"@type":"BreadcrumbList","@id":"https:\/\/devkico.itexto.com.br\/?p=167#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/devkico.itexto.com.br\/"},{"@type":"ListItem","position":2,"name":"JDBC: Maldito Access: como resolver o problema &#8220;n\u00e3o \u00e9 poss\u00edvel abrir mais tabelas (can&#8217;t open more tables)&#8221;"}]},{"@type":"WebSite","@id":"https:\/\/devkico.itexto.com.br\/#website","url":"https:\/\/devkico.itexto.com.br\/","name":"\/dev\/Kico","description":"Desenvolvendo software","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/devkico.itexto.com.br\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"pt-BR"},{"@type":"Person","@id":"https:\/\/devkico.itexto.com.br\/#\/schema\/person\/502ab8892631bb005d6da2269fe5a3a7","name":"Kico (Henrique Lobo Weissmann)","image":{"@type":"ImageObject","inLanguage":"pt-BR","@id":"https:\/\/devkico.itexto.com.br\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/dd6973d86a689bc63122b2e603f25be3?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/dd6973d86a689bc63122b2e603f25be3?s=96&d=mm&r=g","caption":"Kico (Henrique Lobo Weissmann)"},"sameAs":["https:\/\/x.com\/loboweissmann"],"url":"https:\/\/devkico.itexto.com.br\/?author=1"}]}},"jetpack_featured_media_url":"","jetpack-related-posts":[],"jetpack_sharing_enabled":true,"jetpack_likes_enabled":true,"_links":{"self":[{"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=\/wp\/v2\/posts\/167"}],"collection":[{"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=167"}],"version-history":[{"count":3,"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=\/wp\/v2\/posts\/167\/revisions"}],"predecessor-version":[{"id":171,"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=\/wp\/v2\/posts\/167\/revisions\/171"}],"wp:attachment":[{"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=167"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=167"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=167"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}