- A+
前言:本系列文章适合有初/中级.NET知识的同学阅读。
(1)本系列文章,旨在讲述研发一个中大型项目所需要了解的一系列“基本构件”,并提供这些“基本构件”的【最简单】、【最快速】使用方法!!(并不深究技术原理)
(2)通过阅读本系列文章,能让你在正规“项目研发”方面快速入门+进阶,并能达成“小团队构建大网站”的目的。
(3)本系列文章采用的技术,已成功应用到人工智能、产业互联网、社区电商、游戏、金融风控、智慧医疗、等项目上。
限时下载:
常见的ORM技术(比如:Entity Framework,Dapper,SqlSugar,NHibernate,等…),它们不是在做Sql语句的程序化变种,就是在做Sql语句的面向对象化。缺点显而易见:把简单的Sql语句复杂化、不伦不类、非标的各家自定义语法、难以大规模统一应用…
而ADO.NET也存在操作复杂、不同类型数据库(SqlServer、MySql、Oracle、等)操作代码需要重构等缺点。
本文要介绍的主角-DeveloperSharp框架中的ORM数据库访问技术(续),则巧妙的规避了上述各种缺点,提供了一种业界最简单、最高效、最统一的解决方案。
该方案几乎只使用了一个方法/函数,却实现了几乎所有的数据操作功能。它已成功应用到了人工智能、产业互联网、智慧医疗、等多个大型项目上。
此套ORM技术在IDataAccess接口中提供。
IDataAccess所在的命名空间是:DeveloperSharp.Framework.QueryEngine。
它主要提供了如下四大功能:
(1) 执行Sql语句
(2) 执行Sp存储过程
(3) 创建参数(输入/输出/返回)
(4) 事务
它初始化的代码如下:
using DeveloperSharp.Framework.QueryEngine; -------------------------- DatabaseInfo DIF; DIF.DatabaseType = DatabaseType.SQLServer; //设置数据库类型 DIF.ConnectionString = "Server=localhost;Database=YZZ;Uid=sa;Pwd=123"; IDataAccess IDA = DataAccessFactory.Create(DIF);
下面首先直接给出一个“查询多数据+选出单数据+参数”的使用示例,代码如下:
//查询多数据 var Students1 = IDA.SqlExecute<stu>("select * from t_Student"); //查询多数据(带参数) var IdMin = IDA.CreateParameterInput("IdMin", DbType.Int32, 2); var LikeName = IDA.CreateParameterInput("LikeName", DbType.String, 50, "%周%"); var Students2 = IDA.SqlExecute<stu>("select * from t_Student where Id>@IdMin and Name like @LikeName", IdMin, LikeName); //选出单数据 var OneStudent = Students2.FirstOrDefault();
其中stu实体类代码如下形式:
public class stu { public string Name { get; set; } public int Age { get; set; } } //此实体类中的Name、Age属性名,要与数据表中的Name、Age字段名对应
注意:创建参数时使用DbType类型,就是为了能在不同类型数据库(SqlServer、MySql、Oracle、等)之间透明切换!
接着,我们再给出一个“修改数据+参数+事务”的使用示例,代码如下:
try { //开启事务 IDA.TransactionBegin(); //修改数据(多语句) int affectedRows1 = IDA.SqlExecute("insert into t_Student(Name,Age)values('ww','96');update t_Student set Age=100 where Id=1006"); //修改数据(带参数) var NewAge = IDA.CreateParameterInput("NewAge", DbType.Int32, 200); var NewName = IDA.CreateParameterInput("NewName", DbType.String, 50, "孙悟空"); int affectedRows2 = IDA.SqlExecute("insert into t_Student(Name,Age)values(@NewName,@NewAge)", NewName, NewAge); //完成事务 IDA.TransactionCommit(); } catch { //回滚事务 IDA.TransactionRollBack(); }
最后,我们给出一个“聚合函数+输出参数”的使用示例,代码如下:
var IdMax = IDA.CreateParameterInput("IdMax", DbType.Int32, 20); var TotalCount = IDA.CreateParameterOutput("TotalCount", DbType.Int32);//此项为输出参数 var Students3 = IDA.SqlExecute<stu>("select @TotalCount=count(*) from t_Student where Id<@IdMax", TotalCount, IdMax); int tc = (int)TotalCount.Value;
灵活学习+使用以上3个示例,就能满足几乎所有的数据操作需求。
另外,你有没有发现,上述所有的数据操作几乎只用了一个方法来实现:SqlExecute/ SqlExecute<T>
IDataAccess内功能方法详细说明(辅助参考):
SqlExecute<T> 声明:IEnumerable<T> SqlExecute<T>(string cmdText, params IDataParameter[] Params) where T : class, new() 用途:执行Sql语句(Select类) 参数:(1)string cmdText -- Sql语句 (2)params IDataParameter[] Params -- 参数组 返回:IEnumerable<T> -- 多数据结果集 SqlExecute 声明:int SqlExecute(string cmdText, params IDataParameter[] Params) 用途:执行Sql语句(Insert/Update/Delete类) 参数:(1)string cmdText -- Sql语句 (2)params IDataParameter[] Params -- 参数组 返回:int -- 受影响的行数 SpExecute<T> 声明:IEnumerable<T> SpExecute<T>(string cmdText, params IDataParameter[] Params) where T : class, new() 用途:执行Sp存储过程(Select类) 参数:(1)string cmdText -- Sp存储过程名 (2)params IDataParameter[] Params -- 参数组 返回:IEnumerable<T> -- 多数据结果集 SpExecute 声明:int SpExecute(string cmdText, params IDataParameter[] Params) 用途:执行Sp存储过程(Insert/Update/Delete类) 参数:(1)string cmdText -- Sp存储过程名 (2)params IDataParameter[] Params -- 参数组 返回:int -- 受影响的行数
【附注】:文章开头给出的下载示例,均已成功运行通过。但下载示例往往只包含“核心模板”内容,有些辅助内容需要自己建立/设置(比如:数据库创建、链接字符串设置、文件配置、路径设置、参数设定、等等...)。调式时若遇异常报错,请仔细阅读+理解本文。
也随时欢迎联系作者,微信扫描文末二维码,获取更多技术支持!
推荐阅读
- .NET中大型项目开发必备(1)–UUID全球通用唯一识别码
- .NET中大型项目开发必备(2)–CORS跨域访问
- .NET中大型项目开发必备(3)–数据库的负载均衡
- .NET中大型项目开发必备(4)–数据库的读写分离
- .NET中大型项目开发必备(5)–Web服务/WebApi的负载均衡
- .NET中大型项目开发必备(6)–IUtility工具介绍
- .NET中大型项目开发必备(7)–ORM数据库访问技术
- .NET中大型项目开发必备(8)–高效分页
- .NET中大型项目开发必备(9)--http请求调用(Post与Get)
- .NET中大型项目开发必备(10)--图片的裁剪、缩放、与加水印
- .NET中大型项目开发必备(11)--使用Redis缓存
- .NET中大型项目开发必备(12)--使用MQ消息队列
- .NET中大型项目开发必备(13)--ORM数据库访问技术(续)