Sqlsugar调用Oracle的存储过程

前段时间在搬迁项目的时候,遇到一个问题,就是用sqlsugar调用oracle的存储过程的时候调用不了;

当时卡了一整天,现在有空了把这个问题记录分享一下。

先去nuget上安装一下sqlsugar的包:

再安装一个oracle的驱动:

添加一下Json包:

再去创建一下连接

再创建一个测试用的存储过程

复制代码
create or replace procedure pr_test(i_name   in varchar2,
                                    i_age    in varchar2,
                                    o_result out sys_refcursor) as

begin

  open o_result for
    select * from dual;

end pr_test;

创建一个类来接受存储过程返回的数据

复制代码
    public class People
    {
        public string Dummy { get; set; }
    }

单独把存储过程里面的那句sql拿出来执行,会得到下面的结果:

dual这个表是oracle提供的一个表,里面就一个X,一般可以用这个来测试数据库连接是不是正常。

调用的方式如下:

里面那个游标的入参必须是个空字符,我之前尝试过object,null,就是没想到过会是一个空字符。

当时也是没想到一个空字符,就把我卡了一个下午,这个坑应该是不会再踩了。

相关推荐
糖猫猫cc2 天前
Kite:填充处理器
kotlin·orm·kite
老赵全栈实战3 天前
【每日一技MyBatis trim标签核心用法
java·mybatis·orm
canonical_entropy6 天前
Nop入门:EQL集合操作符_some和_all
orm
jnrjian13 天前
ORA-01017 查找机器名 用户名 以及library cache lock 参数含义
数据库·oracle
糖猫猫cc13 天前
Kite:两种方式实现动态表名
java·kotlin·orm·kite
TTc_13 天前
oracle中的union和union all有什么区别?
数据库·oracle
山峰哥13 天前
吃透 SQL 优化:告别慢查询,解锁数据库高性能
服务器·数据库·sql·oracle·性能优化·编辑器
南 阳13 天前
Python从入门到精通day37
数据库·python·oracle
轩情吖13 天前
MySQL库的操作
android·数据库·mysql·oracle·字符集·数据库操作·编码集
脱发的老袁13 天前
【数据库】Oracle手动清理归档日志
数据库·oracle