odp 加固 mysql 代码_在.NetCore(C#)中使用ODP.NET Core+Dapper操作Oracle数据库

前言

Oracle 关系数据库系统是目前世界上流行的关系数据库管理系统,系统可移植性好、使用方便、功能强,适用于各类大、中、小、微机环境。它是一种高效率、可靠性好的 适应高吞吐量的数据库解决方案。

现在的系统主要的技术栈是Java / .Net Core,Java方面不必说对Oracle支持肯定没问题,.Net Core很少会使用到 Oracle数据库。目前我现开发的项目是.Net Core与 Oracle 数据库,所以我想到用.Net Core来写个Oracle数据库访问层,可以方便的使用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语句的代码,类似C#中的DBHelper类。

再看看执行存储过程的…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类型,当然你也可以在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("spGetUser", new {Id = 1},

commandType: CommandType.StoredProcedure).SingleOrDefault();

是不是很方便,更多操作看Dapper文档(本人也是第一次接触Dapper,之前都用EFCore和SqlSugar)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值