{"id":4576,"date":"2013-01-22T21:24:24","date_gmt":"2013-01-23T00:24:24","guid":{"rendered":"http:\/\/www.viamais.net\/blog\/?p=4576"},"modified":"2013-01-22T21:24:24","modified_gmt":"2013-01-23T00:24:24","slug":"abrindo-uma-nova-sessao-para-execucao-do-plsql","status":"publish","type":"post","link":"https:\/\/www.viamais.net\/blog\/abrindo-uma-nova-sessao-para-execucao-do-plsql\/","title":{"rendered":"Abrindo uma nova sess\u00e3o para execu\u00e7\u00e3o do PL\/SQL"},"content":{"rendered":"<p>[ad#texto]<\/p>\n<p>O <b>Oracle<\/b> implementa um controle de sess\u00f5es durante a execu\u00e7\u00e3o de qualquer c\u00f3digo <b>PL\/SQL<\/b> (procedure, trigger, etc), assim um <b>ROLLBACK<\/b> ou um <b>COMMIT<\/b> \u00e9 propagada por toda a sess\u00e3o, esta forma de execu\u00e7\u00e3o geralmente auxilia o trabalho do desenvolvedor, pois o mesmo relega ao <b>Oracle<\/b> o controle sobre sua submiss\u00e3o <b>PL\/SQL<\/b>, por\u00e9m pode ocorrer casos onde precisamos que um trecho espec\u00edfico de PL\/SQL seja executado e tenha um <b>COMMIT<\/b> ou <b>ROLLBACK<\/b> a parte do restante do c\u00f3digo <b>PL\/SQL<\/b>.<\/p>\n<p>Um problema complexo que \u00e9 bem f\u00e1cil de ser resolvido atrav\u00e9s do comando <b>PRAGMA AUTONOMOUS_TRANSACTION<\/b>.<\/p>\n<p>O comando <b>PRAGMA AUTONOMOUS_TRANSACTION<\/b> do <b>PL\/SQL<\/b> tem a capacidade de iniciar uma nova sess\u00e3o para o trecho de c\u00f3digo <b>PL\/SQL<\/b> indicado, assim qualquer execu\u00e7\u00e3o de um <b>ROLLBACK<\/b> ou <b>COMMIT<\/b> ser\u00e1 executado somente dentro da nova sess\u00e3o, n\u00e3o refletindo na sess\u00e3o original.<\/p>\n<p>Este recurso \u00e9 muito utilizado no caso de <i>LOG\u00b4s<\/i>, onde ao levantar uma exce\u00e7\u00e3o a sess\u00e3o original ir\u00e1 efetuar <b>ROLLBACK<\/b>, por\u00e9m faz uma chamada a um <i>PROCEDURE<\/i> que ir\u00e1 inserir dados em uma tabela de LOG\u00b4s, sem o <b>PRAGMA AUTONOMOUS_TRANSACTION<\/b> o <b>ROLLBACK<\/b> da sess\u00e3o original iria apagar os dados gravados no <i>LOG<\/i> durante aquela sess\u00e3o ou o <b>COMMIT<\/b> do processo de <i>LOG<\/i> ir\u00e1 gravar dados do momento da exce\u00e7\u00e3o, resultado em dados gravados em tabela durante um processo err\u00f4neo.<\/p>\n<p>Abaixo segue dois exemplos diferentes do uso de <b>PRAGMA AUTONOMOUS_TRANSACTION<\/b>.<\/p>\n<p>Neste exemplo toda a fun\u00e7\u00e3o da <i>PACKAGE<\/i> especificada ter\u00e1 a capacidade de ser aut\u00f4noma, tudo o que for realizado de <b>COMMIT<\/b> ou <b>ROLLBACK<\/b> ir\u00e1 refletir somente em seu escopo, sem afetar os outros elementos da <i>PACKAGE<\/i>.<\/p>\n<pre lang=\"sql\">CREATE PACKAGE banking AS\r\n...\r\nFUNCTION balance (acct_id INTEGER) RETURN REAL;\r\nEND banking;\r\n\r\nCREATE PACKAGE BODY banking AS\r\n...\r\nFUNCTION balance (acct_id INTEGER) RETURN REAL IS\r\n  PRAGMA AUTONOMOUS_TRANSACTION;\r\n  my_bal REAL;\r\nBEGIN\r\n...\r\nEND;\r\nEND banking;<\/pre>\n<p>Neste outro exemplo de <b>PRAGMA AUTONOMOUS_TRANSACTION<\/b>, vamos ter que toda a <b>TRIGGER<\/b> ser\u00e1 aut\u00f4noma e ao contr\u00e1rio das <b>TRIGGER\u00b4s<\/b> regulares uma <b>TRIGGER<\/b> aut\u00f4noma tem a capacidade de conter declara\u00e7\u00f5es controle de transa\u00e7\u00e3o.<\/p>\n<pre lang=\"sql\">CREATE TRIGGER parts_trigger\r\nBEFORE INSERT ON parts FOR EACH ROW\r\nDECLARE\r\n  PRAGMA AUTONOMOUS_TRANSACTION;\r\nBEGIN\r\n  INSERT INTO parts_log VALUES(:new.pnum, :new.pname);\r\n  COMMIT;\u00a0 -- allowed only in autonomous triggers\r\nEND;<\/pre>\n","protected":false},"excerpt":{"rendered":"<p>[ad#texto] O Oracle implementa um controle de sess\u00f5es durante a execu\u00e7\u00e3o de qualquer c\u00f3digo PL\/SQL<\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"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":"","jetpack_publicize_message":"","jetpack_publicize_feature_enabled":true,"jetpack_social_post_already_shared":false,"jetpack_social_options":{"image_generator_settings":{"template":"highway","default_image_id":0,"font":"","enabled":false},"version":2}},"categories":[26],"tags":[75,39],"class_list":["post-4576","post","type-post","status-publish","format-standard","hentry","category-oracle","tag-oracle","tag-plsql"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v27.4 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>Abrindo uma nova sess\u00e3o para execu\u00e7\u00e3o do PL\/SQL -<\/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.viamais.net\/blog\/abrindo-uma-nova-sessao-para-execucao-do-plsql\/\" \/>\n<meta property=\"og:locale\" content=\"pt_BR\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Abrindo uma nova sess\u00e3o para execu\u00e7\u00e3o do PL\/SQL -\" \/>\n<meta property=\"og:description\" content=\"[ad#texto] O Oracle implementa um controle de sess\u00f5es durante a execu\u00e7\u00e3o de qualquer c\u00f3digo PL\/SQL\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.viamais.net\/blog\/abrindo-uma-nova-sessao-para-execucao-do-plsql\/\" \/>\n<meta property=\"og:site_name\" content=\"ViamaisBLOG\" \/>\n<meta property=\"article:publisher\" content=\"https:\/\/www.facebook.com\/viamais.viablog\" \/>\n<meta property=\"article:author\" content=\"https:\/\/www.facebook.com\/viamais.viablog\" \/>\n<meta property=\"article:published_time\" content=\"2013-01-23T00:24:24+00:00\" \/>\n<meta name=\"author\" content=\"Petter Rafael\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:creator\" content=\"@petterrafael\" \/>\n<meta name=\"twitter:site\" content=\"@petterrafael\" \/>\n<meta name=\"twitter:label1\" content=\"Escrito por\" \/>\n\t<meta name=\"twitter:data1\" content=\"Petter Rafael\" \/>\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\":\"Article\",\"@id\":\"https:\\\/\\\/www.viamais.net\\\/blog\\\/abrindo-uma-nova-sessao-para-execucao-do-plsql\\\/#article\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/www.viamais.net\\\/blog\\\/abrindo-uma-nova-sessao-para-execucao-do-plsql\\\/\"},\"author\":{\"name\":\"Petter Rafael\",\"@id\":\"https:\\\/\\\/www.viamais.net\\\/blog\\\/#\\\/schema\\\/person\\\/a13697c83eb9e9fe998636b42c020ec2\"},\"headline\":\"Abrindo uma nova sess\u00e3o para execu\u00e7\u00e3o do PL\\\/SQL\",\"datePublished\":\"2013-01-23T00:24:24+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\\\/\\\/www.viamais.net\\\/blog\\\/abrindo-uma-nova-sessao-para-execucao-do-plsql\\\/\"},\"wordCount\":346,\"commentCount\":0,\"publisher\":{\"@id\":\"https:\\\/\\\/www.viamais.net\\\/blog\\\/#organization\"},\"keywords\":[\"Oracle\",\"PL\\\/SQL\"],\"articleSection\":[\"Oracle\"],\"inLanguage\":\"pt-BR\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\\\/\\\/www.viamais.net\\\/blog\\\/abrindo-uma-nova-sessao-para-execucao-do-plsql\\\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\\\/\\\/www.viamais.net\\\/blog\\\/abrindo-uma-nova-sessao-para-execucao-do-plsql\\\/\",\"url\":\"https:\\\/\\\/www.viamais.net\\\/blog\\\/abrindo-uma-nova-sessao-para-execucao-do-plsql\\\/\",\"name\":\"Abrindo uma nova sess\u00e3o para execu\u00e7\u00e3o do PL\\\/SQL -\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/www.viamais.net\\\/blog\\\/#website\"},\"datePublished\":\"2013-01-23T00:24:24+00:00\",\"breadcrumb\":{\"@id\":\"https:\\\/\\\/www.viamais.net\\\/blog\\\/abrindo-uma-nova-sessao-para-execucao-do-plsql\\\/#breadcrumb\"},\"inLanguage\":\"pt-BR\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\\\/\\\/www.viamais.net\\\/blog\\\/abrindo-uma-nova-sessao-para-execucao-do-plsql\\\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\\\/\\\/www.viamais.net\\\/blog\\\/abrindo-uma-nova-sessao-para-execucao-do-plsql\\\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"In\u00edcio\",\"item\":\"https:\\\/\\\/www.viamais.net\\\/blog\\\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Oracle\",\"item\":\"https:\\\/\\\/www.viamais.net\\\/blog\\\/category\\\/oracle\\\/\"},{\"@type\":\"ListItem\",\"position\":3,\"name\":\"Abrindo uma nova sess\u00e3o para execu\u00e7\u00e3o do PL\\\/SQL\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\\\/\\\/www.viamais.net\\\/blog\\\/#website\",\"url\":\"https:\\\/\\\/www.viamais.net\\\/blog\\\/\",\"name\":\"ViamaisBLOG\",\"description\":\"Blog de tecnologia com dicas para melhorar sua internet e as novidades de gadgets e aplicativos.\",\"publisher\":{\"@id\":\"https:\\\/\\\/www.viamais.net\\\/blog\\\/#organization\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\\\/\\\/www.viamais.net\\\/blog\\\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"pt-BR\"},{\"@type\":\"Organization\",\"@id\":\"https:\\\/\\\/www.viamais.net\\\/blog\\\/#organization\",\"name\":\"Viablog\",\"url\":\"https:\\\/\\\/www.viamais.net\\\/blog\\\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-BR\",\"@id\":\"https:\\\/\\\/www.viamais.net\\\/blog\\\/#\\\/schema\\\/logo\\\/image\\\/\",\"url\":\"https:\\\/\\\/i0.wp.com\\\/www.viamais.net\\\/blog\\\/wp-content\\\/uploads\\\/2014\\\/10\\\/logo_viamais.png?fit=150%2C150&ssl=1\",\"contentUrl\":\"https:\\\/\\\/i0.wp.com\\\/www.viamais.net\\\/blog\\\/wp-content\\\/uploads\\\/2014\\\/10\\\/logo_viamais.png?fit=150%2C150&ssl=1\",\"width\":150,\"height\":150,\"caption\":\"Viablog\"},\"image\":{\"@id\":\"https:\\\/\\\/www.viamais.net\\\/blog\\\/#\\\/schema\\\/logo\\\/image\\\/\"},\"sameAs\":[\"https:\\\/\\\/www.facebook.com\\\/viamais.viablog\",\"https:\\\/\\\/x.com\\\/petterrafael\"]},{\"@type\":\"Person\",\"@id\":\"https:\\\/\\\/www.viamais.net\\\/blog\\\/#\\\/schema\\\/person\\\/a13697c83eb9e9fe998636b42c020ec2\",\"name\":\"Petter Rafael\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"pt-BR\",\"@id\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/ec1d50795aefe5170d97a2816386714d30fce28bcb746631048cc673d70f8443?s=96&d=identicon&r=g\",\"url\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/ec1d50795aefe5170d97a2816386714d30fce28bcb746631048cc673d70f8443?s=96&d=identicon&r=g\",\"contentUrl\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/ec1d50795aefe5170d97a2816386714d30fce28bcb746631048cc673d70f8443?s=96&d=identicon&r=g\",\"caption\":\"Petter Rafael\"},\"description\":\"Desenvolvedor Web atua com as tecnologias Java e PHP apoiadas pelos bancos de dados Oracle e MySQL. Al\u00e9m dos ambientes de desenvolvimento acima possuiu amplo conhecimento em servidores Apache\\\/Tomcat, Photoshop, Arte &amp; Foto, Flash e mais uma dezena de ferramentas e tecnologias emergentes. Atualmente colabora com o Viablog escrevendo sobre programa\u00e7\u00e3o e tecnologia.\",\"sameAs\":[\"http:\\\/\\\/www.viamais.net\\\/blog\",\"https:\\\/\\\/www.facebook.com\\\/viamais.viablog\"],\"url\":\"https:\\\/\\\/www.viamais.net\\\/blog\\\/author\\\/petterrafael\\\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Abrindo uma nova sess\u00e3o para execu\u00e7\u00e3o do PL\/SQL -","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.viamais.net\/blog\/abrindo-uma-nova-sessao-para-execucao-do-plsql\/","og_locale":"pt_BR","og_type":"article","og_title":"Abrindo uma nova sess\u00e3o para execu\u00e7\u00e3o do PL\/SQL -","og_description":"[ad#texto] O Oracle implementa um controle de sess\u00f5es durante a execu\u00e7\u00e3o de qualquer c\u00f3digo PL\/SQL","og_url":"https:\/\/www.viamais.net\/blog\/abrindo-uma-nova-sessao-para-execucao-do-plsql\/","og_site_name":"ViamaisBLOG","article_publisher":"https:\/\/www.facebook.com\/viamais.viablog","article_author":"https:\/\/www.facebook.com\/viamais.viablog","article_published_time":"2013-01-23T00:24:24+00:00","author":"Petter Rafael","twitter_card":"summary_large_image","twitter_creator":"@petterrafael","twitter_site":"@petterrafael","twitter_misc":{"Escrito por":"Petter Rafael","Est. tempo de leitura":"2 minutos"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/www.viamais.net\/blog\/abrindo-uma-nova-sessao-para-execucao-do-plsql\/#article","isPartOf":{"@id":"https:\/\/www.viamais.net\/blog\/abrindo-uma-nova-sessao-para-execucao-do-plsql\/"},"author":{"name":"Petter Rafael","@id":"https:\/\/www.viamais.net\/blog\/#\/schema\/person\/a13697c83eb9e9fe998636b42c020ec2"},"headline":"Abrindo uma nova sess\u00e3o para execu\u00e7\u00e3o do PL\/SQL","datePublished":"2013-01-23T00:24:24+00:00","mainEntityOfPage":{"@id":"https:\/\/www.viamais.net\/blog\/abrindo-uma-nova-sessao-para-execucao-do-plsql\/"},"wordCount":346,"commentCount":0,"publisher":{"@id":"https:\/\/www.viamais.net\/blog\/#organization"},"keywords":["Oracle","PL\/SQL"],"articleSection":["Oracle"],"inLanguage":"pt-BR","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/www.viamais.net\/blog\/abrindo-uma-nova-sessao-para-execucao-do-plsql\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/www.viamais.net\/blog\/abrindo-uma-nova-sessao-para-execucao-do-plsql\/","url":"https:\/\/www.viamais.net\/blog\/abrindo-uma-nova-sessao-para-execucao-do-plsql\/","name":"Abrindo uma nova sess\u00e3o para execu\u00e7\u00e3o do PL\/SQL -","isPartOf":{"@id":"https:\/\/www.viamais.net\/blog\/#website"},"datePublished":"2013-01-23T00:24:24+00:00","breadcrumb":{"@id":"https:\/\/www.viamais.net\/blog\/abrindo-uma-nova-sessao-para-execucao-do-plsql\/#breadcrumb"},"inLanguage":"pt-BR","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.viamais.net\/blog\/abrindo-uma-nova-sessao-para-execucao-do-plsql\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.viamais.net\/blog\/abrindo-uma-nova-sessao-para-execucao-do-plsql\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"In\u00edcio","item":"https:\/\/www.viamais.net\/blog\/"},{"@type":"ListItem","position":2,"name":"Oracle","item":"https:\/\/www.viamais.net\/blog\/category\/oracle\/"},{"@type":"ListItem","position":3,"name":"Abrindo uma nova sess\u00e3o para execu\u00e7\u00e3o do PL\/SQL"}]},{"@type":"WebSite","@id":"https:\/\/www.viamais.net\/blog\/#website","url":"https:\/\/www.viamais.net\/blog\/","name":"ViamaisBLOG","description":"Blog de tecnologia com dicas para melhorar sua internet e as novidades de gadgets e aplicativos.","publisher":{"@id":"https:\/\/www.viamais.net\/blog\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.viamais.net\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"pt-BR"},{"@type":"Organization","@id":"https:\/\/www.viamais.net\/blog\/#organization","name":"Viablog","url":"https:\/\/www.viamais.net\/blog\/","logo":{"@type":"ImageObject","inLanguage":"pt-BR","@id":"https:\/\/www.viamais.net\/blog\/#\/schema\/logo\/image\/","url":"https:\/\/i0.wp.com\/www.viamais.net\/blog\/wp-content\/uploads\/2014\/10\/logo_viamais.png?fit=150%2C150&ssl=1","contentUrl":"https:\/\/i0.wp.com\/www.viamais.net\/blog\/wp-content\/uploads\/2014\/10\/logo_viamais.png?fit=150%2C150&ssl=1","width":150,"height":150,"caption":"Viablog"},"image":{"@id":"https:\/\/www.viamais.net\/blog\/#\/schema\/logo\/image\/"},"sameAs":["https:\/\/www.facebook.com\/viamais.viablog","https:\/\/x.com\/petterrafael"]},{"@type":"Person","@id":"https:\/\/www.viamais.net\/blog\/#\/schema\/person\/a13697c83eb9e9fe998636b42c020ec2","name":"Petter Rafael","image":{"@type":"ImageObject","inLanguage":"pt-BR","@id":"https:\/\/secure.gravatar.com\/avatar\/ec1d50795aefe5170d97a2816386714d30fce28bcb746631048cc673d70f8443?s=96&d=identicon&r=g","url":"https:\/\/secure.gravatar.com\/avatar\/ec1d50795aefe5170d97a2816386714d30fce28bcb746631048cc673d70f8443?s=96&d=identicon&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/ec1d50795aefe5170d97a2816386714d30fce28bcb746631048cc673d70f8443?s=96&d=identicon&r=g","caption":"Petter Rafael"},"description":"Desenvolvedor Web atua com as tecnologias Java e PHP apoiadas pelos bancos de dados Oracle e MySQL. Al\u00e9m dos ambientes de desenvolvimento acima possuiu amplo conhecimento em servidores Apache\/Tomcat, Photoshop, Arte &amp; Foto, Flash e mais uma dezena de ferramentas e tecnologias emergentes. Atualmente colabora com o Viablog escrevendo sobre programa\u00e7\u00e3o e tecnologia.","sameAs":["http:\/\/www.viamais.net\/blog","https:\/\/www.facebook.com\/viamais.viablog"],"url":"https:\/\/www.viamais.net\/blog\/author\/petterrafael\/"}]}},"jetpack_publicize_connections":[],"jetpack_featured_media_url":"","jetpack_shortlink":"https:\/\/wp.me\/p5Ih4c-1bO","jetpack-related-posts":[{"id":4512,"url":"https:\/\/www.viamais.net\/blog\/laco-while-no-oracle-plsql\/","url_meta":{"origin":4576,"position":0},"title":"La\u00e7o WHILE no Oracle PL\/SQL","author":"Petter Rafael","date":"11\/01\/2013","format":false,"excerpt":"[ad#texto] J\u00e1 falamos anteriormente sobre uma das formas de fazer um LOOP no PL\/SQL, vamos agora mostrar outra, utilizando WHILE. A sintaxe \u00e9 parecida, contudo o controle de sa\u00edda do LOOP fica na pr\u00f3pria declara\u00e7\u00e3o do WHILE e n\u00e3o no comando EXIT como do outro exemplo. Veja um exemplo: WHILE\u2026","rel":"","context":"Em &quot;Oracle&quot;","block_context":{"text":"Oracle","link":"https:\/\/www.viamais.net\/blog\/category\/oracle\/"},"img":{"alt_text":"","src":"","width":0,"height":0},"classes":[]},{"id":4910,"url":"https:\/\/www.viamais.net\/blog\/tunning-oracle-trabalhando-o-contexto\/","url_meta":{"origin":4576,"position":1},"title":"Tunning Oracle, trabalhando o contexto","author":"Petter Rafael","date":"25\/03\/2013","format":false,"excerpt":"[ad#texto] O Oracle \u00e9 um banco de dados que vem evoluindo a muitas d\u00e9cadas, na sua origem ele apenas comportava SQL, a linguagem PL\/SQL foi desenvolvida posteriormente pela Oracle e foi sendo inserida e melhorada aos poucos, internamente a Oracle criou dois ambientes distintos de processamento, um para o SQL\u2026","rel":"","context":"Em &quot;Dicas&quot;","block_context":{"text":"Dicas","link":"https:\/\/www.viamais.net\/blog\/category\/dicas\/"},"img":{"alt_text":"","src":"","width":0,"height":0},"classes":[]},{"id":1631,"url":"https:\/\/www.viamais.net\/blog\/chamando-procedure-do-oracle-no-php\/","url_meta":{"origin":4576,"position":2},"title":"Chamando procedure do Oracle no PHP","author":"Petter Rafael","date":"01\/12\/2009","format":false,"excerpt":"Para quem trabalha com PHP e Oracle, vez ou outra pode surgir a necessidade de chamar uma procedure direta do Oracle em seu script PHP. O processo \u00e9 simples e basta utilizar PL\/SQL para executar a procedure dentro do seu script PHP, por exemplo, suponha que voc\u00ea precise chamar a\u2026","rel":"","context":"Em &quot;Oracle&quot;","block_context":{"text":"Oracle","link":"https:\/\/www.viamais.net\/blog\/category\/oracle\/"},"img":{"alt_text":"","src":"","width":0,"height":0},"classes":[]},{"id":3253,"url":"https:\/\/www.viamais.net\/blog\/verificando-cursores-no-plsql\/","url_meta":{"origin":4576,"position":3},"title":"Verificando cursores no PL\/SQL","author":"Petter Rafael","date":"14\/12\/2011","format":false,"excerpt":"[ad#texto] Todo desenvolvedor PL\/SQL utiliza constantemente cursores, seja pela praticidade, ou seja, pela necessidade mesmo, mas existe um pequeno detalhe que constantemente vejo desenvolvedores Oracle (mesmo os mais experientes) esquecerem: validar se o cursor j\u00e1 n\u00e3o est\u00e1 aberto. Caso a sua aplica\u00e7\u00e3o, por um descuido tente abrir um cursor j\u00e1\u2026","rel":"","context":"Em &quot;Oracle&quot;","block_context":{"text":"Oracle","link":"https:\/\/www.viamais.net\/blog\/category\/oracle\/"},"img":{"alt_text":"","src":"","width":0,"height":0},"classes":[]},{"id":5158,"url":"https:\/\/www.viamais.net\/blog\/agendando-tarefas-no-oracle\/","url_meta":{"origin":4576,"position":4},"title":"Agendando tarefas no Oracle","author":"Petter Rafael","date":"20\/05\/2013","format":false,"excerpt":"[ad#texto] Precisando agendar a execu\u00e7\u00e3o de um objeto no Oracle e n\u00e3o sabe como? No Oracle temos um recurso chamado de JOB, com ele \u00e9 poss\u00edvel agendar execu\u00e7\u00f5es de tempos em tempos de qualquer objeto \u201cexecut\u00e1vel\u201d em PL\/SQL. Veja um exemplo: DECLARE jobno NUMBER; BEGIN DBMS_JOB.submit(jobno,'MINHa_PROC;', sysdate, sysdate + 5\/1440);\u2026","rel":"","context":"Em &quot;Oracle&quot;","block_context":{"text":"Oracle","link":"https:\/\/www.viamais.net\/blog\/category\/oracle\/"},"img":{"alt_text":"","src":"","width":0,"height":0},"classes":[]},{"id":6425,"url":"https:\/\/www.viamais.net\/blog\/tuning-oracle-operacoes-aritmeticas-plsql\/","url_meta":{"origin":4576,"position":5},"title":"Tuning Oracle: opera\u00e7\u00f5es aritm\u00e9ticas PL\/SQL","author":"Petter Rafael","date":"10\/07\/2014","format":false,"excerpt":"Veja como detalhes podem fazer toda a diferen\u00e7a quando falamos em tuning Oracle. Veja detalhes de como deixar sua aplica\u00e7\u00e3o PL\/SQL mais r\u00e1pida. [ad#texto] Um detalhe que muitos ignoram quando falamos de performance e desempenho cr\u00edtico \u00e9 o cuidado ao declarar vari\u00e1veis locais para inteiros, elas podem ser decisivas no\u2026","rel":"","context":"Em &quot;Dicas&quot;","block_context":{"text":"Dicas","link":"https:\/\/www.viamais.net\/blog\/category\/dicas\/"},"img":{"alt_text":"Tuning Oracle: opera\u00e7\u00f5es aritm\u00e9ticas PL\/SQL","src":"https:\/\/i0.wp.com\/www.viamais.net\/blog\/wp-content\/uploads\/2014\/05\/como-importar-um-arquivo-xml-para-o-oracle.jpg?resize=350%2C200","width":350,"height":200},"classes":[]}],"jetpack_sharing_enabled":true,"jetpack_likes_enabled":false,"_links":{"self":[{"href":"https:\/\/www.viamais.net\/blog\/wp-json\/wp\/v2\/posts\/4576","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.viamais.net\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.viamais.net\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.viamais.net\/blog\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/www.viamais.net\/blog\/wp-json\/wp\/v2\/comments?post=4576"}],"version-history":[{"count":0,"href":"https:\/\/www.viamais.net\/blog\/wp-json\/wp\/v2\/posts\/4576\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.viamais.net\/blog\/wp-json\/wp\/v2\/media?parent=4576"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.viamais.net\/blog\/wp-json\/wp\/v2\/categories?post=4576"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.viamais.net\/blog\/wp-json\/wp\/v2\/tags?post=4576"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}