暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

Oracle pragma autonous_transaction; 和数据库链接

askTom 2017-11-27
267

问题描述

我有一个通过链接从SqlServer数据库返回数据的函数包。
通常结果只是显示在网页或客户端程序的可选字段中。

它们采取以下形式:
function get_info(ar_key number) 
return varchar2 as
   v_return varchar2(256);
begin
   select "info"
     into v_return
     from "table"@foreignsqldb
    where "key" = ar_key;
   return v_return;
exception
   when no data found
      return '';
end;
复制


这些函数用于从Oracle数据库返回。
但是因为现在是sql,所以我担心孤立的事务会锁定那里的东西。
我知道pragma autonous_transaction有一个不好的代表,但这将是一个有效的用途:

function get_info(ar_key number) 
return varchar2 as
   pragma autonomous_transaction;
   v_return varchar2(256);
begin
   select "info"
     into v_return
     from "table"@foreignsqldb
    where "key" = ar_key;
   rollback; 
   return v_return;
exception
   when no data found
      rollback;
      return '';
end;
复制


TIA

专家解答

我对SQL Server中的读取锁的理解是,一旦您的查询完成,它们就会被释放。

因此,假设您的查询旨在很好且快速 (即,其中key =... ),那么您不需要开始/终止交易。


「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论