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,就是没想到过会是一个空字符。

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

相关推荐
Irene19911 小时前
Oracle:为什么 ORDER BY 能让 SUM() 变成累计?
oracle
早日退休!!!7 小时前
《数据结构选型指南》笔记
数据结构·数据库·oracle
阿坤带你走近大数据10 小时前
怎么查看当前oracle库下的表空间temp大小或者默认大小
数据库·oracle
hljqfl14 小时前
Oracle存储结构
数据库·oracle
m0_7162550016 小时前
批处理一道例题+答案解析+批处理知识点总结 | 批处理高频易错场景 + 正确写法对照表
数据库·oracle
俺不要写代码16 小时前
数据库:DML
数据库·oracle
Irene199117 小时前
Oracle 中:为什么 from 子查询后面需要一个别名
数据库·oracle
杨云龙UP18 小时前
Oracle数据库启动失败:ORA-29701、ORA-01565、ORA-17503故障处理记录_20260429
linux·运维·数据库·oracle·centos
懒铭心19 小时前
Oracle 19c 备份与恢复
oracle
于歌85219 小时前
Oracle批处理操作方法
数据库·oracle