{"id":73,"date":"2008-09-08T08:13:24","date_gmt":"2008-09-08T11:13:24","guid":{"rendered":"https:\/\/devkico.itexto.com.br\/?p=73"},"modified":"2008-09-08T08:13:24","modified_gmt":"2008-09-08T11:13:24","slug":"grails-acessando-bases-de-dados-legadas","status":"publish","type":"post","link":"https:\/\/devkico.itexto.com.br\/?p=73","title":{"rendered":"Grails: acessando bases de dados legadas."},"content":{"rendered":"<p>Ent\u00e3o chegou o dia no qual voc\u00ea conheceu Grails, se apaixonou pelo bichinho mas n\u00e3o sabe ainda como configur\u00e1-lo para acessar sua base de dados legada. Ao primeiro contato com Grails, uma impress\u00e3o que surge \u00e9 que, para criarmos algo com o bichinho, precisamos partir do zero no que diz respeito a base de dados. Felizmente nada poderia ser mais distante da verdade.<\/p>\n<p>Se voc\u00ea j\u00e1 possui uma base de dados legada, e gostaria de reaproveit\u00e1-la em sua aplica\u00e7\u00e3o feita em Grails, apresento-lhe a propriedade <strong>mapping<\/strong>, respons\u00e1vel por permitir ao desenvolvedor customizar o modo como Grails acessa suas bases de dados (leia aqui: o <em>chato<\/em> do legado). \u00c9 neste bloco de c\u00f3digo aonde definimos, por exemplo, o nome dos campos que queremos acessar em nossa aplica\u00e7\u00e3o.<\/p>\n<p>Sendo assim, suponhamos que eu j\u00e1 possua em um banco de dados (n\u00e3o irei explicar aqui como configurar a conex\u00e3o com o mesmo, pois o assunto do t\u00f3pico consiste apenas em como customizar o mapeamento de nossas classes com suas respectivas tabelas) uma tabela chamada <em>tbUsuario<\/em>. Esta foi definida tal como descrito abaixo (n\u00e3o costumo dar estes nomes a meus campos. Irei usar aqui nomes que se afastem o m\u00e1ximo poss\u00edvel dos padr\u00f5es normalmente criados pelo Grails):<\/p>\n<pre class=\"brush: java; title: ; notranslate\" title=\"\">\r\ncreate table tbUsuario (\r\nidUsuario varchar(36) not null,\r\nstrNome varchar(128) not null,\r\nstrLogin varchar(64) not null,\r\nstrSenha varchar(128) not null,\r\nprimary key (Id)\r\n)\r\n<\/pre>\n<p>Nossa tabela utiliza como chave prim\u00e1ria o campo idUsuario que armazena valores gerados usando o algoritmo UUID, diferente do padr\u00e3o definido pelo Grails quando trabalhamos com MySQL por exemplo (neste caso, Grails utiliza valores auto incrementais).<\/p>\n<p>Suponhamos agora, que nossa classe de dom\u00ednio possua o c\u00f3digo definido abaixo:<\/p>\n<pre class=\"brush: java; title: ; notranslate\" title=\"\">\r\nclass Usuario {\r\nString nome\r\nString login\r\nString senha\r\n\r\nstatic constraints = {\r\nnome(maxSize: 128, nullable:false, blank:false, unique: true)\r\nlogin(maxSize: 64, nullable:false, blank:false, unique: true)\r\nsenha(maxSize: 128, nullable:false, blank:false)\r\n}\r\n}\r\n<\/pre>\n<p>Se fossemos usar o padr\u00e3o do Grails para a gera\u00e7\u00e3o de tabelas no MySQL, gerariamos em nosso banco uma tabela tal como a descrita no c\u00f3digo abaixo:<\/p>\n<pre class=\"brush: java; title: ; notranslate\" title=\"\">\r\ncreate table usuario {\r\nid integer not null auto_increment,\r\nversion integer not null, \/\/ para versionamento do banco, o Grails cria este campo por default\r\nnome varchar(128) not null,\r\nlogin varchar(128) not null,\r\nsenha varchar(128) not null,\r\nprimary key (id),\r\n\/\/ e algum c\u00f3digo para a gera\u00e7\u00e3o dos indices unicos para os campos login e nome\r\n}\r\n<\/pre>\n<p>Como pode ser observado, a tabela gerada por default \u00e9 muito diferente da que intencionamos usar. Para resolver este problema, iremos incluir o bloco de c\u00f3digo mapping em nossa classe de dom\u00ednio, tal como no c\u00f3digo abaixo:<\/p>\n<pre class=\"brush: java; title: ; notranslate\" title=\"\">\r\nclass Usuario {\r\nString id \/\/ repare: estou redefinindo o atributo id como String.\r\nString nome\r\nString login\r\nString senha\r\n\r\nstatic constraints = {\r\nnome(maxSize: 128, nullable:false, blank:false, unique: true)\r\nlogin(maxSize: 64, nullable:false, blank:false, unique: true)\r\nsenha(maxSize: 128, nullable:false, blank:false)\r\n}\r\n\r\nstatic mapping = {\r\ntable &#039;tbUsuario&#039;\r\nversion false\r\nid column:&#039;idUsuario&#039;, generator:&#039;uuid&#039;\r\nnome column:&#039;strNome&#039;\r\nlogin column:&#039;strLogin&#039;\r\nsenha column:&#039;strSenha&#039;\r\n}\r\n}\r\n<\/pre>\n<p>Vamos agora analisar o que foi feito no bloco mapping linha a linha (ou quase):<\/p>\n<pre class=\"brush: java; title: ; notranslate\" title=\"\">\r\ntable &#039;tbUsuario&#039;\r\n<\/pre>\n<p>Simples: defino qual o nome da tabela na qual os dados se encontram armazenados.<\/p>\n<pre class=\"brush: java; title: ; notranslate\" title=\"\">\r\nversion false\r\n<\/pre>\n<p>O Grails por default cria um campo chamado version em suas tabelas para versionamento dos dados. Podemos desabilitar este padr\u00e3o usando o comando acima. Dado que em nossa base de dados legada n\u00e3o existe campo similar, ignorar este detalhe iria travar nossa aplica\u00e7\u00e3o.<\/p>\n<pre class=\"brush: java; title: ; notranslate\" title=\"\">\r\nid column:&#039;idUsuario&#039;, generator:&#039;uuid&#039;\r\n<\/pre>\n<p>Como n\u00e3o iremos usar o padr\u00e3o para armazenamento de chaves prim\u00e1rias, que varia de acordo com o banco de dados (MySQL, por exemplo, tem por default campos incrementais no que diz respeito a chaves prim\u00e1rias), precisamos redefinir nossa coluna id.<\/p>\n<p>No caso, primeiro definimos qual o nome da coluna na qual os dados est\u00e3o armazenados. Em seguida, definimos qual o algoritmo usado na gera\u00e7\u00e3o destes valores. Em nosso caso, o algoritmo UUID (j\u00e1 inclusive escrevi sobre isto <a href=\"https:\/\/devkico.itexto.com.br\/?p=53\" target=\"_blank\">aqui<\/a>).<\/p>\n<p>Com rela\u00e7\u00e3o aos demais campos, apenas foi definido o nome relacionado \u00e0 tabela em quest\u00e3o:<\/p>\n<pre class=\"brush: java; title: ; notranslate\" title=\"\">\r\nnome column:&#039;strNome&#039;\r\nlogin column:&#039;strLogin&#039;\r\nsenha column:&#039;strSenha&#039;\r\n<\/pre>\n<p>E por incr\u00edvel que pare\u00e7a, basicamente \u00e9 isto o que voc\u00ea precisa fazer caso queira lidar com bases de dados legadas. Todo o c\u00f3digo CRUD referente a classe de dom\u00ednio em quest\u00e3o ser\u00e1 feito com base nestas customiza\u00e7\u00f5es.<\/p>\n<p>Caso queira se aprofundar mais sobre o assunto, sugiro que d\u00ea uma lida na pr\u00f3pria documenta\u00e7\u00e3o do Grails (ali\u00e1s, excelente) clicando <a href=\"http:\/\/grails.org\/doc\/1.0.x\/guide\/single.html#5.5.2 Custom ORM Mapping\" target=\"_blank\">aqui<\/a>.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Ent\u00e3o chegou o dia no qual voc\u00ea conheceu Grails, se apaixonou pelo bichinho mas n\u00e3o sabe ainda como configur\u00e1-lo para acessar sua base de dados legada. Ao primeiro contato com Grails, uma impress\u00e3o que surge \u00e9 que, para criarmos algo com o bichinho, precisamos partir do zero no que diz respeito a base de dados. [&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":[3,5],"tags":[],"class_list":["post-73","post","type-post","status-publish","format-standard","hentry","category-grails","category-groovy"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v22.8 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>Grails: acessando bases de dados legadas. - \/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=73\" \/>\n<meta property=\"og:locale\" content=\"pt_BR\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Grails: acessando bases de dados legadas. - \/dev\/Kico\" \/>\n<meta property=\"og:description\" content=\"Ent\u00e3o chegou o dia no qual voc\u00ea conheceu Grails, se apaixonou pelo bichinho mas n\u00e3o sabe ainda como configur\u00e1-lo para acessar sua base de dados legada. Ao primeiro contato com Grails, uma impress\u00e3o que surge \u00e9 que, para criarmos algo com o bichinho, precisamos partir do zero no que diz respeito a base de dados. [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/devkico.itexto.com.br\/?p=73\" \/>\n<meta property=\"og:site_name\" content=\"\/dev\/Kico\" \/>\n<meta property=\"article:published_time\" content=\"2008-09-08T11:13:24+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=\"4 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=73\",\"url\":\"https:\/\/devkico.itexto.com.br\/?p=73\",\"name\":\"Grails: acessando bases de dados legadas. - \/dev\/Kico\",\"isPartOf\":{\"@id\":\"https:\/\/devkico.itexto.com.br\/#website\"},\"datePublished\":\"2008-09-08T11:13:24+00:00\",\"dateModified\":\"2008-09-08T11:13:24+00:00\",\"author\":{\"@id\":\"https:\/\/devkico.itexto.com.br\/#\/schema\/person\/502ab8892631bb005d6da2269fe5a3a7\"},\"breadcrumb\":{\"@id\":\"https:\/\/devkico.itexto.com.br\/?p=73#breadcrumb\"},\"inLanguage\":\"pt-BR\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/devkico.itexto.com.br\/?p=73\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/devkico.itexto.com.br\/?p=73#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/devkico.itexto.com.br\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Grails: acessando bases de dados legadas.\"}]},{\"@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":"Grails: acessando bases de dados legadas. - \/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=73","og_locale":"pt_BR","og_type":"article","og_title":"Grails: acessando bases de dados legadas. - \/dev\/Kico","og_description":"Ent\u00e3o chegou o dia no qual voc\u00ea conheceu Grails, se apaixonou pelo bichinho mas n\u00e3o sabe ainda como configur\u00e1-lo para acessar sua base de dados legada. Ao primeiro contato com Grails, uma impress\u00e3o que surge \u00e9 que, para criarmos algo com o bichinho, precisamos partir do zero no que diz respeito a base de dados. [&hellip;]","og_url":"https:\/\/devkico.itexto.com.br\/?p=73","og_site_name":"\/dev\/Kico","article_published_time":"2008-09-08T11:13:24+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":"4 minutos"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/devkico.itexto.com.br\/?p=73","url":"https:\/\/devkico.itexto.com.br\/?p=73","name":"Grails: acessando bases de dados legadas. - \/dev\/Kico","isPartOf":{"@id":"https:\/\/devkico.itexto.com.br\/#website"},"datePublished":"2008-09-08T11:13:24+00:00","dateModified":"2008-09-08T11:13:24+00:00","author":{"@id":"https:\/\/devkico.itexto.com.br\/#\/schema\/person\/502ab8892631bb005d6da2269fe5a3a7"},"breadcrumb":{"@id":"https:\/\/devkico.itexto.com.br\/?p=73#breadcrumb"},"inLanguage":"pt-BR","potentialAction":[{"@type":"ReadAction","target":["https:\/\/devkico.itexto.com.br\/?p=73"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/devkico.itexto.com.br\/?p=73#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/devkico.itexto.com.br\/"},{"@type":"ListItem","position":2,"name":"Grails: acessando bases de dados legadas."}]},{"@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\/73"}],"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=73"}],"version-history":[{"count":5,"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=\/wp\/v2\/posts\/73\/revisions"}],"predecessor-version":[{"id":79,"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=\/wp\/v2\/posts\/73\/revisions\/79"}],"wp:attachment":[{"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=73"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=73"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/devkico.itexto.com.br\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=73"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}