{"id":598,"date":"2024-06-08T13:08:08","date_gmt":"2024-06-08T16:08:08","guid":{"rendered":"https:\/\/www.isacaguiar.com.br\/blog\/?p=598"},"modified":"2024-06-05T18:10:39","modified_gmt":"2024-06-05T21:10:39","slug":"utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono","status":"publish","type":"post","link":"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/","title":{"rendered":"Utilizando Oracle Advanced Queuing (AQ) com Spring Data Source e JDBC para Processamento Ass\u00edncrono"},"content":{"rendered":"<h4>Introdu\u00e7\u00e3o<\/h4>\n<p>O Oracle Advanced Queuing (AQ) \u00e9 uma solu\u00e7\u00e3o de enfileiramento nativa do Oracle Database, projetada para gerenciar mensagens e processos ass\u00edncronos. Quando integrado ao Spring Data Source e JDBC, o Oracle AQ se torna uma ferramenta poderosa para comunica\u00e7\u00e3o ass\u00edncrona em sistemas distribu\u00eddos. Este artigo detalha como configurar e utilizar o Oracle AQ com Spring Data Source e JDBC para realizar opera\u00e7\u00f5es de enfileiramento e desenfileiramento de mensagens.<\/p>\n<h4>Configura\u00e7\u00e3o do Spring Data Source<\/h4>\n<h5>1. Configura\u00e7\u00e3o via <code>application.properties<\/code><\/h5>\n<p>Essa abordagem \u00e9 a maneira mais simples e recomendada para configurar o DataSource quando voc\u00ea est\u00e1 usando Spring Boot. Aqui est\u00e1 um exemplo de configura\u00e7\u00e3o:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"wp-block-preformatted prism line-numbers lang-properties\" data-lang=\"Properties\"><code class=\"language-properties\">spring.datasource.url=jdbc:oracle:thin:@localhost:1521:xe\r\nspring.datasource.username=seu_usuario\r\nspring.datasource.password=sua_senha\r\nspring.datasource.driver-class-name=oracle.jdbc.OracleDriver\r\n<\/code><\/pre>\n<\/div>\n<h5>2. Configura\u00e7\u00e3o Program\u00e1tica (opcional)<\/h5>\n<p>Se voc\u00ea precisar de uma configura\u00e7\u00e3o mais personalizada ou condicional, voc\u00ea pode definir um <code>DataSourceConfig<\/code> program\u00e1tico como uma op\u00e7\u00e3o secund\u00e1ria. Aqui est\u00e1 um exemplo de como fazer isso:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"wp-block-preformatted prism line-numbers lang-java\" data-lang=\"Java\"><code class=\"language-java\">import org.springframework.context.annotation.Bean;\r\nimport org.springframework.context.annotation.Configuration;\r\nimport org.springframework.jdbc.core.JdbcTemplate;\r\nimport org.springframework.jdbc.datasource.DriverManagerDataSource;\r\n\r\nimport javax.sql.DataSource;\r\n\r\n@Configuration\r\npublic class DataSourceConfig {\r\n\r\n    @Bean\r\n    public DataSource dataSource() {\r\n        DriverManagerDataSource dataSource = new DriverManagerDataSource();\r\n        dataSource.setDriverClassName(\"oracle.jdbc.OracleDriver\");\r\n        dataSource.setUrl(\"jdbc:oracle:thin:@localhost:1521:xe\");\r\n        dataSource.setUsername(\"seu_usuario\");\r\n        dataSource.setPassword(\"sua_senha\");\r\n        return dataSource;\r\n    }\r\n\r\n    @Bean\r\n    public JdbcTemplate jdbcTemplate(DataSource dataSource) {\r\n        return new JdbcTemplate(dataSource);\r\n    }\r\n}\r\n<\/code><\/pre>\n<\/div>\n<p>A anota\u00e7\u00e3o <code>@ConditionalOnMissingBean<\/code> garante que essa configura\u00e7\u00e3o s\u00f3 ser\u00e1 usada se n\u00e3o houver outro <code>DataSource<\/code> ou <code>JdbcTemplate<\/code> definido, permitindo que a configura\u00e7\u00e3o via <code>application.properties<\/code> seja priorizada.<\/p>\n<h4>Enfileiramento de Mensagens<\/h4>\n<p>Para enfileirar uma mensagem em uma fila do Oracle AQ, use uma chamada PL\/SQL atrav\u00e9s do <code>JdbcTemplate<\/code> do Spring. O exemplo abaixo mostra como enfileirar uma mensagem:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"wp-block-preformatted prism line-numbers lang-java\" data-lang=\"Java\"><code class=\"language-java\">import org.springframework.beans.factory.annotation.Autowired;\r\nimport org.springframework.jdbc.core.JdbcTemplate;\r\nimport org.springframework.stereotype.Service;\r\n\r\n@Service\r\npublic class QueueService {\r\n\r\n    @Autowired\r\n    private JdbcTemplate jdbcTemplate;\r\n\r\n    public void enqueueMessage(String queueName, String message) {\r\n        String enqueueSql = \"DECLARE \" +\r\n                            \"  enqueue_options DBMS_AQ.ENQUEUE_OPTIONS_T; \" +\r\n                            \"  message_properties DBMS_AQ.MESSAGE_PROPERTIES_T; \" +\r\n                            \"  message_id RAW(16); \" +\r\n                            \"  message RAW(100); \" +\r\n                            \"BEGIN \" +\r\n                            \"  message := UTL_RAW.CAST_TO_RAW(?); \" +\r\n                            \"  DBMS_AQ.ENQUEUE( \" +\r\n                            \"    queue_name =&gt; ?, \" +\r\n                            \"    enqueue_options =&gt; enqueue_options, \" +\r\n                            \"    message_properties =&gt; message_properties, \" +\r\n                            \"    payload =&gt; message, \" +\r\n                            \"    msgid =&gt; message_id \" +\r\n                            \"  ); \" +\r\n                            \"  COMMIT; \" +\r\n                            \"END;\";\r\n\r\n        jdbcTemplate.update(enqueueSql, message, queueName);\r\n    }\r\n}\r\n<\/code><\/pre>\n<\/div>\n<h4>Desenfileiramento de Mensagens<\/h4>\n<p>Para desenfileirar uma mensagem de uma fila do Oracle AQ, utilize uma chamada PL\/SQL atrav\u00e9s do <code>JdbcTemplate<\/code>. O exemplo a seguir mostra como desenfileirar uma mensagem:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"wp-block-preformatted prism line-numbers lang-java\" data-lang=\"Java\"><code class=\"language-java\">import org.springframework.beans.factory.annotation.Autowired;\r\nimport org.springframework.jdbc.core.JdbcTemplate;\r\nimport org.springframework.stereotype.Service;\r\n\r\n@Service\r\npublic class QueueService {\r\n\r\n    @Autowired\r\n    private JdbcTemplate jdbcTemplate;\r\n\r\n    public String dequeueMessage(String queueName) {\r\n        String dequeueSql = \"DECLARE \" +\r\n                            \"  dequeue_options DBMS_AQ.DEQUEUE_OPTIONS_T; \" +\r\n                            \"  message_properties DBMS_AQ.MESSAGE_PROPERTIES_T; \" +\r\n                            \"  message_id RAW(16); \" +\r\n                            \"  message RAW(100); \" +\r\n                            \"BEGIN \" +\r\n                            \"  DBMS_AQ.DEQUEUE( \" +\r\n                            \"    queue_name =&gt; ?, \" +\r\n                            \"    dequeue_options =&gt; dequeue_options, \" +\r\n                            \"    message_properties =&gt; message_properties, \" +\r\n                            \"    payload =&gt; message, \" +\r\n                            \"    msgid =&gt; message_id \" +\r\n                            \"  ); \" +\r\n                            \"  DBMS_OUTPUT.PUT_LINE(UTL_RAW.CAST_TO_VARCHAR2(message)); \" +\r\n                            \"  COMMIT; \" +\r\n                            \"END;\";\r\n\r\n        return jdbcTemplate.queryForObject(dequeueSql, new Object[]{queueName}, String.class);\r\n    }\r\n}\r\n<\/code><\/pre>\n<\/div>\n<h4>Exemplo de Uso<\/h4>\n<p>A seguir, um exemplo de como utilizar o servi\u00e7o <code>QueueService<\/code> para enfileirar e desenfileirar mensagens:<\/p>\n<div class=\"hcb_wrap\">\n<pre class=\"wp-block-preformatted prism line-numbers lang-java\" data-lang=\"Java\"><code class=\"language-java\">import org.springframework.beans.factory.annotation.Autowired;\r\nimport org.springframework.boot.CommandLineRunner;\r\nimport org.springframework.stereotype.Component;\r\n\r\n@Component\r\npublic class QueueRunner implements CommandLineRunner {\r\n\r\n    @Autowired\r\n    private QueueService queueService;\r\n\r\n    @Override\r\n    public void run(String... args) throws Exception {\r\n        \/\/ Enfileirar uma mensagem\r\n        queueService.enqueueMessage(\"my_queue\", \"Minha mensagem\");\r\n\r\n        \/\/ Desenfileirar uma mensagem\r\n        String message = queueService.dequeueMessage(\"my_queue\");\r\n        System.out.println(\"Mensagem desenfileirada: \" + message);\r\n    }\r\n}\r\n<\/code>\r\n<\/pre>\n<\/div>\n<h4>Conclus\u00e3o<\/h4>\n<p>Integrar o Oracle Advanced Queuing (AQ) com Spring Data Source e JDBC \u00e9 uma solu\u00e7\u00e3o poderosa para implementar processamento ass\u00edncrono em aplica\u00e7\u00f5es que j\u00e1 utilizam o Oracle Database. Atrav\u00e9s das opera\u00e7\u00f5es de enfileiramento e desenfileiramento descritas neste artigo, \u00e9 poss\u00edvel aproveitar as vantagens do AQ, como durabilidade e confiabilidade das mensagens, para construir sistemas distribu\u00eddos eficientes e escal\u00e1veis. Essa abordagem garante que diferentes partes da aplica\u00e7\u00e3o possam se comunicar de forma ass\u00edncrona, melhorando a robustez e a capacidade de resposta do sistema como um todo.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Introdu\u00e7\u00e3o O Oracle Advanced Queuing (AQ) \u00e9 uma solu\u00e7\u00e3o de enfileiramento nativa do Oracle Database, projetada para gerenciar mensagens e processos ass\u00edncronos.\u2026<\/p>\n","protected":false},"author":1,"featured_media":602,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[18,13,30,17],"tags":[],"class_list":["post-598","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-desenvolvimento-de-software","category-java","category-mensageria","category-oracle"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v27.2 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>Utilizando Oracle Advanced Queuing (AQ) com Spring Data Source e JDBC para Processamento Ass\u00edncrono - Blog do Aguiar<\/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:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/\" \/>\n<meta property=\"og:locale\" content=\"pt_BR\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Utilizando Oracle Advanced Queuing (AQ) com Spring Data Source e JDBC para Processamento Ass\u00edncrono - Blog do Aguiar\" \/>\n<meta property=\"og:description\" content=\"Introdu\u00e7\u00e3o O Oracle Advanced Queuing (AQ) \u00e9 uma solu\u00e7\u00e3o de enfileiramento nativa do Oracle Database, projetada para gerenciar mensagens e processos ass\u00edncronos.\u2026\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog do Aguiar\" \/>\n<meta property=\"article:publisher\" content=\"https:\/\/www.facebook.com\/isac.velozo.aguiar\" \/>\n<meta property=\"article:published_time\" content=\"2024-06-08T16:08:08+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/www.isacaguiar.com.br\/blog\/wp-content\/uploads\/2024\/06\/DALL\u00b7E-2024-06-05-13.17.55-An-image-for-an-article-titled-Utilizando-Oracle-Advanced-Queuing-AQ-com-Spring-Data-Source-e-JDBC-para-Processamento-Assincrono.-The-image-featur.webp\" \/>\n\t<meta property=\"og:image:width\" content=\"1024\" \/>\n\t<meta property=\"og:image:height\" content=\"1024\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/webp\" \/>\n<meta name=\"author\" content=\"isacaguiar\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Escrito por\" \/>\n\t<meta name=\"twitter:data1\" content=\"isacaguiar\" \/>\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\":\"Article\",\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/\"},\"author\":{\"name\":\"isacaguiar\",\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/#\/schema\/person\/78719359439f068d8b1e5e0bcb9d934d\"},\"headline\":\"Utilizando Oracle Advanced Queuing (AQ) com Spring Data Source e JDBC para Processamento Ass\u00edncrono\",\"datePublished\":\"2024-06-08T16:08:08+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/\"},\"wordCount\":360,\"image\":{\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/#primaryimage\"},\"thumbnailUrl\":\"https:\/\/www.isacaguiar.com.br\/blog\/wp-content\/uploads\/2024\/06\/DALL\u00b7E-2024-06-05-13.17.55-An-image-for-an-article-titled-Utilizando-Oracle-Advanced-Queuing-AQ-com-Spring-Data-Source-e-JDBC-para-Processamento-Assincrono.-The-image-featur.webp\",\"articleSection\":[\"Desenvolvimento de Software\",\"Java\",\"Mensageria\",\"Oracle\"],\"inLanguage\":\"pt-BR\"},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/\",\"url\":\"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/\",\"name\":\"Utilizando Oracle Advanced Queuing (AQ) com Spring Data Source e JDBC para Processamento Ass\u00edncrono - Blog do Aguiar\",\"isPartOf\":{\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/#primaryimage\"},\"image\":{\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/#primaryimage\"},\"thumbnailUrl\":\"https:\/\/www.isacaguiar.com.br\/blog\/wp-content\/uploads\/2024\/06\/DALL\u00b7E-2024-06-05-13.17.55-An-image-for-an-article-titled-Utilizando-Oracle-Advanced-Queuing-AQ-com-Spring-Data-Source-e-JDBC-para-Processamento-Assincrono.-The-image-featur.webp\",\"datePublished\":\"2024-06-08T16:08:08+00:00\",\"author\":{\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/#\/schema\/person\/78719359439f068d8b1e5e0bcb9d934d\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/#breadcrumb\"},\"inLanguage\":\"pt-BR\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-BR\",\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/#primaryimage\",\"url\":\"https:\/\/www.isacaguiar.com.br\/blog\/wp-content\/uploads\/2024\/06\/DALL\u00b7E-2024-06-05-13.17.55-An-image-for-an-article-titled-Utilizando-Oracle-Advanced-Queuing-AQ-com-Spring-Data-Source-e-JDBC-para-Processamento-Assincrono.-The-image-featur.webp\",\"contentUrl\":\"https:\/\/www.isacaguiar.com.br\/blog\/wp-content\/uploads\/2024\/06\/DALL\u00b7E-2024-06-05-13.17.55-An-image-for-an-article-titled-Utilizando-Oracle-Advanced-Queuing-AQ-com-Spring-Data-Source-e-JDBC-para-Processamento-Assincrono.-The-image-featur.webp\",\"width\":1024,\"height\":1024},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"In\u00edcio\",\"item\":\"http:\/\/www.isacaguiar.com.br\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Utilizando Oracle Advanced Queuing (AQ) com Spring Data Source e JDBC para Processamento Ass\u00edncrono\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/#website\",\"url\":\"https:\/\/www.isacaguiar.com.br\/blog\/\",\"name\":\"Blog do Aguiar\",\"description\":\"\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/www.isacaguiar.com.br\/blog\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"pt-BR\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.isacaguiar.com.br\/blog\/#\/schema\/person\/78719359439f068d8b1e5e0bcb9d934d\",\"name\":\"isacaguiar\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-BR\",\"@id\":\"https:\/\/secure.gravatar.com\/avatar\/e22bb054d1154f07e6c91b82f0d68a219b6b04b58e5e3692c30cf457b51a9e9f?s=96&d=mm&r=g\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/e22bb054d1154f07e6c91b82f0d68a219b6b04b58e5e3692c30cf457b51a9e9f?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/e22bb054d1154f07e6c91b82f0d68a219b6b04b58e5e3692c30cf457b51a9e9f?s=96&d=mm&r=g\",\"caption\":\"isacaguiar\"},\"url\":\"https:\/\/www.isacaguiar.com.br\/blog\/author\/isacaguiar\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Utilizando Oracle Advanced Queuing (AQ) com Spring Data Source e JDBC para Processamento Ass\u00edncrono - Blog do Aguiar","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:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/","og_locale":"pt_BR","og_type":"article","og_title":"Utilizando Oracle Advanced Queuing (AQ) com Spring Data Source e JDBC para Processamento Ass\u00edncrono - Blog do Aguiar","og_description":"Introdu\u00e7\u00e3o O Oracle Advanced Queuing (AQ) \u00e9 uma solu\u00e7\u00e3o de enfileiramento nativa do Oracle Database, projetada para gerenciar mensagens e processos ass\u00edncronos.\u2026","og_url":"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/","og_site_name":"Blog do Aguiar","article_publisher":"https:\/\/www.facebook.com\/isac.velozo.aguiar","article_published_time":"2024-06-08T16:08:08+00:00","og_image":[{"width":1024,"height":1024,"url":"https:\/\/www.isacaguiar.com.br\/blog\/wp-content\/uploads\/2024\/06\/DALL\u00b7E-2024-06-05-13.17.55-An-image-for-an-article-titled-Utilizando-Oracle-Advanced-Queuing-AQ-com-Spring-Data-Source-e-JDBC-para-Processamento-Assincrono.-The-image-featur.webp","type":"image\/webp"}],"author":"isacaguiar","twitter_card":"summary_large_image","twitter_misc":{"Escrito por":"isacaguiar","Est. tempo de leitura":"4 minutos"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/#article","isPartOf":{"@id":"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/"},"author":{"name":"isacaguiar","@id":"https:\/\/www.isacaguiar.com.br\/blog\/#\/schema\/person\/78719359439f068d8b1e5e0bcb9d934d"},"headline":"Utilizando Oracle Advanced Queuing (AQ) com Spring Data Source e JDBC para Processamento Ass\u00edncrono","datePublished":"2024-06-08T16:08:08+00:00","mainEntityOfPage":{"@id":"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/"},"wordCount":360,"image":{"@id":"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/#primaryimage"},"thumbnailUrl":"https:\/\/www.isacaguiar.com.br\/blog\/wp-content\/uploads\/2024\/06\/DALL\u00b7E-2024-06-05-13.17.55-An-image-for-an-article-titled-Utilizando-Oracle-Advanced-Queuing-AQ-com-Spring-Data-Source-e-JDBC-para-Processamento-Assincrono.-The-image-featur.webp","articleSection":["Desenvolvimento de Software","Java","Mensageria","Oracle"],"inLanguage":"pt-BR"},{"@type":"WebPage","@id":"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/","url":"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/","name":"Utilizando Oracle Advanced Queuing (AQ) com Spring Data Source e JDBC para Processamento Ass\u00edncrono - Blog do Aguiar","isPartOf":{"@id":"https:\/\/www.isacaguiar.com.br\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/#primaryimage"},"image":{"@id":"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/#primaryimage"},"thumbnailUrl":"https:\/\/www.isacaguiar.com.br\/blog\/wp-content\/uploads\/2024\/06\/DALL\u00b7E-2024-06-05-13.17.55-An-image-for-an-article-titled-Utilizando-Oracle-Advanced-Queuing-AQ-com-Spring-Data-Source-e-JDBC-para-Processamento-Assincrono.-The-image-featur.webp","datePublished":"2024-06-08T16:08:08+00:00","author":{"@id":"https:\/\/www.isacaguiar.com.br\/blog\/#\/schema\/person\/78719359439f068d8b1e5e0bcb9d934d"},"breadcrumb":{"@id":"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/#breadcrumb"},"inLanguage":"pt-BR","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/"]}]},{"@type":"ImageObject","inLanguage":"pt-BR","@id":"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/#primaryimage","url":"https:\/\/www.isacaguiar.com.br\/blog\/wp-content\/uploads\/2024\/06\/DALL\u00b7E-2024-06-05-13.17.55-An-image-for-an-article-titled-Utilizando-Oracle-Advanced-Queuing-AQ-com-Spring-Data-Source-e-JDBC-para-Processamento-Assincrono.-The-image-featur.webp","contentUrl":"https:\/\/www.isacaguiar.com.br\/blog\/wp-content\/uploads\/2024\/06\/DALL\u00b7E-2024-06-05-13.17.55-An-image-for-an-article-titled-Utilizando-Oracle-Advanced-Queuing-AQ-com-Spring-Data-Source-e-JDBC-para-Processamento-Assincrono.-The-image-featur.webp","width":1024,"height":1024},{"@type":"BreadcrumbList","@id":"https:\/\/www.isacaguiar.com.br\/blog\/utilizando-oracle-advanced-queuing-aq-com-spring-data-source-e-jdbc-para-processamento-assincrono\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"In\u00edcio","item":"http:\/\/www.isacaguiar.com.br\/blog\/"},{"@type":"ListItem","position":2,"name":"Utilizando Oracle Advanced Queuing (AQ) com Spring Data Source e JDBC para Processamento Ass\u00edncrono"}]},{"@type":"WebSite","@id":"https:\/\/www.isacaguiar.com.br\/blog\/#website","url":"https:\/\/www.isacaguiar.com.br\/blog\/","name":"Blog do Aguiar","description":"","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.isacaguiar.com.br\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"pt-BR"},{"@type":"Person","@id":"https:\/\/www.isacaguiar.com.br\/blog\/#\/schema\/person\/78719359439f068d8b1e5e0bcb9d934d","name":"isacaguiar","image":{"@type":"ImageObject","inLanguage":"pt-BR","@id":"https:\/\/secure.gravatar.com\/avatar\/e22bb054d1154f07e6c91b82f0d68a219b6b04b58e5e3692c30cf457b51a9e9f?s=96&d=mm&r=g","url":"https:\/\/secure.gravatar.com\/avatar\/e22bb054d1154f07e6c91b82f0d68a219b6b04b58e5e3692c30cf457b51a9e9f?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/e22bb054d1154f07e6c91b82f0d68a219b6b04b58e5e3692c30cf457b51a9e9f?s=96&d=mm&r=g","caption":"isacaguiar"},"url":"https:\/\/www.isacaguiar.com.br\/blog\/author\/isacaguiar\/"}]}},"amp_enabled":true,"_links":{"self":[{"href":"https:\/\/www.isacaguiar.com.br\/blog\/wp-json\/wp\/v2\/posts\/598","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.isacaguiar.com.br\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.isacaguiar.com.br\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.isacaguiar.com.br\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.isacaguiar.com.br\/blog\/wp-json\/wp\/v2\/comments?post=598"}],"version-history":[{"count":18,"href":"https:\/\/www.isacaguiar.com.br\/blog\/wp-json\/wp\/v2\/posts\/598\/revisions"}],"predecessor-version":[{"id":686,"href":"https:\/\/www.isacaguiar.com.br\/blog\/wp-json\/wp\/v2\/posts\/598\/revisions\/686"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.isacaguiar.com.br\/blog\/wp-json\/wp\/v2\/media\/602"}],"wp:attachment":[{"href":"https:\/\/www.isacaguiar.com.br\/blog\/wp-json\/wp\/v2\/media?parent=598"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.isacaguiar.com.br\/blog\/wp-json\/wp\/v2\/categories?post=598"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.isacaguiar.com.br\/blog\/wp-json\/wp\/v2\/tags?post=598"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}