欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

在.NetCore(C#)中使用ODP.NET Core+Dapper操作Oracle数据库

程序员文章站 2022-04-03 20:34:10
前言虽然一直在说“去ioe化”,但是在国企和*,oracle的历史包袱实在太重了,甚至很多业务逻辑都是写在oracle的各种存储过程里面实现的……我们的系统主要的技术栈是django / sprin...

前言

虽然一直在说“去ioe化”,但是在国企和*,oracle的历史包袱实在太重了,甚至很多业务逻辑都是写在oracle的各种存储过程里面实现的……

我们的系统主要的技术栈是django / spring / aspnetcore,java的不必说对oracle支持肯定没问题,关键在于django对oracle版本有要求,兼容性不是特别好,oracle版本没办法随意升级的,所以我想到用.net core来写个中间层,让其他系统可以方便的使用oracle的数据和存储过程…

odp.net core是一个ado.net驱动程序,提供从microsoft .net core客户端到oracle数据库的快速数据访问。它可以在windows和linux上运行。odp.net由一个100%托管代码动态链接库oracle.manageddataaccess.dll组成,可通过nuget安装获得。

这个 oracle.manageddataaccess.core 是真的方便,不用安装oracle客户端,兼容性、便捷性,反正就是开箱即用,一把梭就完事了

简单使用

首先用nuget安装这个 oracle.manageddataaccess.core ,之后就可以执各类操作了,不过从代码量上看还是比较繁琐的,上代码:

这就是执行 select * from table_name 这条sql语句的代码,有点长…… 吐了

再看看执行存储过程的…

这里去掉了错误处理,显得短一点,不过还是麻烦得不行……

所以这里我们要用dapper这个轻量级orm来简化操作

使用dapper

不多说,首先nuget安装是常规操作,包名就是简单的 dapper 。

首先是增删改查这类普通的sql语句:

可以看到引入dapper之后只要使用 oracleconnection 的扩展方法 query 来执行sql就行了~ 返回的结果是 ienumerable<dynamic> 类型,当然你也可以在 query 方法的泛型参数里指定返回的类型,我这里为了通用就不指定了

继续看存储过程的,很简单,更上面的差不多,就多一个参数告诉程序我们的sql类型是啥而已

如果是有带参数的存储过程咋办?

很简单(代码来自官方例子)~

ok,很方便,更多操作看dapper文档就完事了(我也是第一次接触dapper,之前都用freesql和efcore),此文完结~

dapper项目主页: https://github.com/stackexchange/dapper

参考资料

.net core 使用odp.net core连接操作oracle数据库:
元件開箱:managed odp.net for linux

到此这篇关于在.netcore(c#)中使用odp.net core+dapper操作oracle数据库的文章就介绍到这了,更多相关.netcore操作oracle数据库内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!