固然一直在说“去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 ,之后就可以执种种操纵了,不外从代码量上看照旧较量繁琐的,上代码:
var connStr = $"DATA SOURCE=127.0.0.1/db_name; PASSWORD=password; PERSIST SECURITY INFO=True; USER ID=user_id"; using (var conn = new OracleConnection(connStr)) { using (var command = conn.CreateCommand()) { try { if (conn.State == ConnectionState.Closed) { conn.Open(); } command.BindByName = true; command.CommandText = $"select * from table_name"; using (var reader = command.ExecuteReader()) { while (reader.Read()) { Console.WriteLine(reader.GetString("DEPART_NAME")); } } } catch (Exception ex) { Console.WriteLine(ex.StackTrace); Console.WriteLine(ex.Source); Console.WriteLine(ex.Message); } } }
这就是执行 select * from table_name 这条SQL语句的代码,有点长…… 吐了
再看看执行存储进程的…
var connStr = $"DATA SOURCE=127.0.0.1/db_name; PASSWORD=password; PERSIST SECURITY INFO=True; USER ID=user_id"; using (var conn = new OracleConnection(connStr)) { conn.Open(); var command = new OracleCommand("proc_name", conn) { CommandType = CommandType.StoredProcedure }; // 输入参数 command.Parameters.Add(new OracleParameter("id", "0001")); // 输出参数 var vOut = new OracleParameter("v_out", OracleDbType.Varchar2, 1000, "", ParameterDirection.InputOutput ); command.Parameters.Add(vOut); var affectRows = command.ExecuteNonQuery(); Console.WriteLine(vOut.Value); }
这里去掉了错误处理惩罚,显得短一点,不外照旧贫苦得不可……
所以这里我们要用Dapper这个轻量级ORM来简化操纵
利用Dapper不多说,首先nuget安装是通例操纵,包名就是简朴的 Dapper 。
首先是增删改查这类普通的SQL语句:
using Dapper; var connStr = $"DATA SOURCE=127.0.0.1/db_name; PASSWORD=password; PERSIST SECURITY INFO=True; USER ID=user_id"; using var cn = new OracleConnection(connStr); var result = cn.Query("select * from table_name"); foreach (var item in result) { Console.WriteLine(item); }
可以看到引入Dapper之后只要利用 OracleConnection 的扩展要领 Query 来执行SQL就行了~ 返回的功效是 IEnumerable<dynamic> 范例,虽然你也可以在 Query 要领的泛型参数里指定返回的范例,我这里为了通用就不指定了
继承看存储进程的,很简朴,更上面的差不多,就多一个参数汇报措施我们的SQL范例是啥罢了
var connStr = $"DATA SOURCE=127.0.0.1/db_name; PASSWORD=password; PERSIST SECURITY INFO=True; USER ID=user_id"; using var cn = new OracleConnection(connStr); var result = cn.Query("proc_name", commandType: CommandType.StoredProcedure); foreach (var item in result) { Console.WriteLine(item); }
假如是有带参数的存储进程咋办?
很简朴(代码来自官方例子)~
var user = cnn.Query<User>("spGetUser", new {Id = 1}, commandType: CommandType.StoredProcedure).SingleOrDefault();
ok,很利便,更多操纵看Dapper文档就完事了(我也是第一次打仗Dapper,之前都用FreeSQL和EFCore),此文完结~
Dapper项目主页: https://github.com/StackExchange/Dapper
参考资料.NET Core 利用ODP.NET Core毗连操纵Oracle数据库: https://www.cjavapy.com/article/271/
元件開箱:Managed ODP.NET for Linux
到此这篇关于在.NetCore(C#)中利用ODP.NET Core+Dapper操纵Oracle数据库的文章就先容到这了,更多相关.NetCore操纵Oracle数据库内容请搜索剧本之家以前的文章或继承欣赏下面的相关文章但愿各人今后多多支持剧本之家!
您大概感乐趣的文章: