{"id":56,"date":"2008-08-26T23:23:39","date_gmt":"2008-08-27T02:23:39","guid":{"rendered":"https:\/\/devkico.itexto.com.br\/?p=56"},"modified":"2008-08-26T23:23:39","modified_gmt":"2008-08-27T02:23:39","slug":"gambiarra-esperta-trabalhando-com-mais-de-um-banco-de-dados-usando-hibernate-ou-qualquer-ferramenta-orm","status":"publish","type":"post","link":"https:\/\/devkico.itexto.com.br\/?p=56","title":{"rendered":"Gambiarra esperta: trabalhando com mais de um banco de dados usando Hibernate (ou qualquer ferramenta ORM)"},"content":{"rendered":"<p>Hibernate \u00e9 fenomenal, mas tem um problema: quando precisamos lidar com mais de um banco de dados, as coisas se complicam. Neste post pretendo mostrar como superar esta &#8220;limita\u00e7\u00e3o&#8221; do Hibernate usando um padr\u00e3o (confesso: orientado a gambi, mas funciona bem!) que facilita esta tarefa.<\/p>\n<p>Por\u00e9m, antes de come\u00e7ar, vamos supor a seguinte situa\u00e7\u00e3o: existem dois bancos de dados: bdUsuarios, aonde est\u00e3o armazenadas informa\u00e7\u00f5es relativas aos usu\u00e1rios do seu sistema e outro, chamado bdNegocios, aonde ficam as tabelas relativas \u00e0s suas classes de neg\u00f3cio.<\/p>\n<p>Para piorar um pouco mais a situa\u00e7\u00e3o, vamos supor que todas as suas classes relativas ao gerenciamento de seus usu\u00e1rios j\u00e1 se encontrem prontas, armazenadas em um arquivo jar (traduzindo: j\u00e1 se encontram inclusive mapeadas para acessar os dados presentes no banco de dados bdUsuarios).<\/p>\n<p>Ok: suponhamos agora que exista uma classe chamada Evento, que encontre-se definida tal como no c\u00f3digo abaixo:<\/p>\n<pre class=\"brush: java; title: ; notranslate\" title=\"\">\r\nclass Evento {\r\n          private String id\r\n          private Date data\r\n          private Usuario usuario\r\n          private String mensagem\r\n          \/\/ gets e sets omitidos\r\n}\r\n<\/pre>\n<p>Os dados da classe Evento dever\u00e3o ser armazenados no banco de dados bdNegocios. A primeira coisa que poder\u00e1 passar pela cabe\u00e7a do leitor ser\u00e1: &#8220;hmm&#8230; bastaria alterar as configura\u00e7\u00f5es de acesso ao banco de dados do Hibernate!&#8221;. Por\u00e9m, a solu\u00e7\u00e3o \u00e9 bem mais simples. Basta criar o que chamo de &#8220;propriedades <i>ORM only<\/i>&#8220;.<\/p>\n<p>Uma propriedade <i>ORM only<\/i> seria aquela utilizada APENAS pelo mecanismo de ORM. No nosso caso, suponhamos que queiramos armazenar os dados referentes \u00e0 classe Evento na tabela evento, cuja estrutura encontra-se exposta abaixo:<\/p>\n<pre class=\"brush: sql; title: ; notranslate\" title=\"\">\r\n   create table evento (\r\n          id varchar(36) not null,\r\n          idUsuario varchar(36) not null, \r\n          data timestamp not null,\r\n          mensagem varchar(255) not null,\r\n          primary key(id)\r\n    )\r\n<\/pre>\n<p>Incluiriamos as nossas propriedades <i>ORM only<\/i> em nossa classe Evento tal como no c\u00f3digo abaixo:<\/p>\n<pre class=\"brush: java; title: ; notranslate\" title=\"\">\r\n  (...)\r\n   \/\/ Para uso somente do ORM\r\n   public String getIdUsuario() {\r\n         return getUsuario() == null ? null : getUsuario().getId();\r\n   }\r\n\r\n   \/\/ Para uso somente do ORM\r\n   public void setIdUsuario(String valor) {\r\n         \/\/ Suponha que exista um construtor para usuario que carregue seus dados a partir do id\r\n         try {\r\n               setUsuario(new Usuario(valor));\r\n           } catch (ErroUsuarioNaoEncontrado ex) {\r\n              setUsuario(null);\r\n           }\r\n   }\r\n  (...)\r\n<\/pre>\n<p>Em seguida, vamos ao nosso arquivo de mapeamento da classe Evento:<\/p>\n<pre class=\"brush: xml; title: ; notranslate\" title=\"\">\r\n(...)\r\n&lt;class name=&quot;meupacote.Evento&quot; table=&quot;evento&quot;&gt;\r\n     &lt;id name=&quot;id&quot; column=&quot;id&quot;&gt;\r\n          &lt;generator class=&quot;uuid&quot;\/&gt;\r\n     &lt;\/id&gt;\r\n     &lt;property name=&quot;data&quot;\/&gt;\r\n     &lt;property name=&quot;mensagem&quot;\/&gt;\r\n     &lt;!-- O pulo do gato! --&gt;\r\n     &lt;property name=&quot;idUsuario&quot; column=&quot;idUsuario&quot;\/&gt;\r\n&lt;\/class&gt;\r\n<\/pre>\n<p>No mapeamento, mapeamos uma propriedade chamada idUsuario, que corresponder\u00e1 \u00e0 respectiva <i>ORM only<\/i> de nossa classe Evento. O Hibernate pensar\u00e1 que se trata de apenas uma propriedade do tipo varchar(36), no entanto, no interior do set e do get, estaremos, na realidade, lidando com a classe Usuario. <\/p>\n<p>Como j\u00e1 mencionei, trata-se de uma solu\u00e7\u00e3o um tanto quanto <i>&#8220;gambi&#8221;<\/i>, no entanto, foi a \u00fanica que encontrei para solucionar o problema e, espero, o seu tamb\u00e9m!<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Hibernate \u00e9 fenomenal, mas tem um problema: quando precisamos lidar com mais de um banco de dados, as coisas se complicam. Neste post pretendo mostrar como superar esta &#8220;limita\u00e7\u00e3o&#8221; do Hibernate usando um padr\u00e3o (confesso: orientado a gambi, mas funciona bem!) que facilita esta tarefa. Por\u00e9m, antes de come\u00e7ar, vamos supor a seguinte situa\u00e7\u00e3o: existem [&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":[7,6,1],"tags":[],"class_list":["post-56","post","type-post","status-publish","format-standard","hentry","category-hibernate","category-java","category-uncategorized"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v22.8 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>Gambiarra esperta: trabalhando com mais de um banco de dados usando Hibernate (ou qualquer ferramenta ORM) - \/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=56\" \/>\n<meta property=\"og:locale\" content=\"pt_BR\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Gambiarra esperta: trabalhando com mais de um banco de dados usando Hibernate (ou qualquer ferramenta ORM) - \/dev\/Kico\" \/>\n<meta property=\"og:description\" content=\"Hibernate \u00e9 fenomenal, mas tem um problema: quando precisamos lidar com mais de um banco de dados, as coisas se complicam. Neste post pretendo mostrar como superar esta &#8220;limita\u00e7\u00e3o&#8221; do Hibernate usando um padr\u00e3o (confesso: orientado a gambi, mas funciona bem!) que facilita esta tarefa. Por\u00e9m, antes de come\u00e7ar, vamos supor a seguinte situa\u00e7\u00e3o: existem [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/devkico.itexto.com.br\/?p=56\" \/>\n<meta property=\"og:site_name\" content=\"\/dev\/Kico\" \/>\n<meta property=\"article:published_time\" content=\"2008-08-27T02:23:39+00:00\" \/>\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=\"2 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=56\",\"url\":\"https:\/\/devkico.itexto.com.br\/?p=56\",\"name\":\"Gambiarra esperta: trabalhando com mais de um banco de dados usando Hibernate (ou qualquer ferramenta ORM) - \/dev\/Kico\",\"isPartOf\":{\"@id\":\"https:\/\/devkico.itexto.com.br\/#website\"},\"datePublished\":\"2008-08-27T02:23:39+00:00\",\"dateModified\":\"2008-08-27T02:23:39+00:00\",\"author\":{\"@id\":\"https:\/\/devkico.itexto.com.br\/#\/schema\/person\/502ab8892631bb005d6da2269fe5a3a7\"},\"breadcrumb\":{\"@id\":\"https:\/\/devkico.itexto.com.br\/?p=56#breadcrumb\"},\"inLanguage\":\"pt-BR\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/devkico.itexto.com.br\/?p=56\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/devkico.itexto.com.br\/?p=56#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/devkico.itexto.com.br\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Gambiarra esperta: trabalhando com mais de um banco de dados usando Hibernate (ou qualquer ferramenta ORM)\"}]},{\"@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":"Gambiarra esperta: trabalhando com mais de um banco de dados usando Hibernate (ou qualquer ferramenta ORM) - \/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=56","og_locale":"pt_BR","og_type":"article","og_title":"Gambiarra esperta: trabalhando com mais de um banco de dados usando Hibernate (ou qualquer ferramenta ORM) - \/dev\/Kico","og_description":"Hibernate \u00e9 fenomenal, mas tem um problema: quando precisamos lidar com mais de um banco de dados, as coisas se complicam. Neste post pretendo mostrar como superar esta &#8220;limita\u00e7\u00e3o&#8221; do Hibernate usando um padr\u00e3o (confesso: orientado a gambi, mas funciona bem!) que facilita esta tarefa. Por\u00e9m, antes de come\u00e7ar, vamos supor a seguinte situa\u00e7\u00e3o: existem [&hellip;]","og_url":"https:\/\/devkico.itexto.com.br\/?p=56","og_site_name":"\/dev\/Kico","article_published_time":"2008-08-27T02:23:39+00:00","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":"2 minutos"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/devkico.itexto.com.br\/?p=56","url":"https:\/\/devkico.itexto.com.br\/?p=56","name":"Gambiarra esperta: trabalhando com mais de um banco de dados usando Hibernate (ou qualquer ferramenta ORM) - \/dev\/Kico","isPartOf":{"@id":"https:\/\/devkico.itexto.com.br\/#website"},"datePublished":"2008-08-27T02:23:39+00:00","dateModified":"2008-08-27T02:23:39+00:00","author":{"@id":"https:\/\/devkico.itexto.com.br\/#\/schema\/person\/502ab8892631bb005d6da2269fe5a3a7"},"breadcrumb":{"@id":"https:\/\/devkico.itexto.com.br\/?p=56#breadcrumb"},"inLanguage":"pt-BR","potentialAction":[{"@type":"ReadAction","target":["https:\/\/devkico.itexto.com.br\/?p=56"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/devkico.itexto.com.br\/?p=56#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/devkico.itexto.com.br\/"},{"@type":"ListItem","position":2,"name":"Gambiarra esperta: trabalhando com mais de um banco de dados usando Hibernate (ou qualquer ferramenta ORM)"}]},{"@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\/56"}],"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=56"}],"version-history":[{"count":2,"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=\/wp\/v2\/posts\/56\/revisions"}],"predecessor-version":[{"id":58,"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=\/wp\/v2\/posts\/56\/revisions\/58"}],"wp:attachment":[{"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=56"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=56"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=56"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}