.NET中大型项目开发必备(13)--DataAccess数据库访问技术(续)

互联网 2022/5/21 19:04:46

前言:本系列文章适合有初/中级.NET知识的同学阅读(请在电脑上打开页面,获取更好的阅读效果)。(1)本系列文章,旨在讲述研发一个中大型项目所需要了解的一系列“基本构件”,并提供这些“基本构件”在全网的【最简单】、【最快速】使用方法!!(并不深究技术原理)(…

前言:本系列文章适合有初/中级.NET知识的同学阅读(请在电脑上打开页面,获取更好的阅读效果)。
(1)本系列文章,旨在讲述研发一个中大型项目所需要了解的一系列“基本构件”,并提供这些“基本构件”在全网的【最简单】、【最快速】使用方法!!(并不深究技术原理)
(2)通过阅读本系列文章,能让你在正规“项目研发”方面快速入门+进阶,并能达成“小团队构建大网站”的目的。
(3)本系列文章采用的技术,已成功应用到人工智能、产业互联网、社区电商、游戏、金融风控、智慧医疗、等项目上。

限时下载:

nuget搜索关键字:DeveloperSharp

 

常见的ORM技术(比如:Entity Framework,Dapper,SqlSugar,NHibernate,等…),它们不是在做Sql语句的程序化变种,就是在做Sql语句的面向对象化。虽然有“逻辑较清晰”、“统一异质数据库Sql语法差异”的优势,但它们的缺点也显而易见:

(1)     把简单的Sql语句复杂化、不伦不类

(2)     速度慢、性能下降严重

(3)     有时功能不全,有时又有未知错误+不停发补丁

(4)     非标的各家自定义语法、且一些自定义破坏了原生.Net/C#以及Sql语言的协调性

(5)     难以大规模统一应用…

 

本文要介绍的主角-DeveloperSharp框架中的DataAccess数据库访问技术(续),则提供了一种基于原生Sql操作为核心的解决方案,也巧妙的规避了上述各种缺点。(注:未来视必要也能发展成面向对象程序化)

该方案几乎只使用了一个方法/函数,却实现了几乎所有的数据操作功能。它已成功应用到了人工智能、产业互联网、智慧医疗、等多个大型项目上。

 

此套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);

 注意:通过对DatabaseType属性的设定,提供了对各不同种类数据库的支持(包括:MySql、Oracle、PostgreSQL、SqlServer、Sqlite、Firebird、达梦、以及人大金仓KingbaseES、神舟通用, 南大通用, 翰高, Access、等)

 

【示例1:查询】

下面,首先直接给出一个“查询多数据+选出单数据+参数”的使用示例,代码如下:

   //查询多数据
   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 Students3 = IDA.SqlExecute<stu>("select * from t_Student").Where(t => t.Id > 2 && t.Name.Contains("周"));

   //选出单数据
   var OneStudent = Students2.FirstOrDefault();

其中stu实体类代码如下形式:

public class stu
{
        public int Id { get; set; }
        public string Name { get; set; }
        public int Age { get; set; }
}
//此实体类中的Id、Name、Age属性名,要与数据表中的Id、Name、Age字段名对应

注意:创建参数时使用DbType类型,就是为了能在不同类型数据库(SqlServer、MySql、Oracle、等)之间透明切换!

 

【示例2:分页】

承接上面“示例1”的代码,若我们要对Students1、Students2进行分页操作(比如:每页20条,取出第5页),相关代码如下:

using DeveloperSharp.Extension;//调用“分页功能”需要引用此命名空间
--------------------------

   var Page1 = Students1.PagePartition(20, 5);
   var Page2 = Students2.PagePartition(20, 5);

   //一气呵成的写法
   var Page3 = IDA.SqlExecute<stu>("select * from t_Student").PagePartition(20, 5);

  

【示例3:增/删/改】

前面谈完“查询”,我们接下来谈谈“增/删/改”的使用方式,下面是一个“修改数据+参数+事务”的使用示例:

   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();
   }

 

【示例4:其它】

最后,我们给出一个“聚合函数+输出参数”的使用示例,代码如下:

   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;

灵活学习+使用以上4个示例,就能满足几乎所有的数据操作需求。

另外,你有没有发现,上述所有的数据操作几乎只用了一个方法来实现:SqlExecute/ SqlExecute<T>

 

推荐指数★★★★★

优势1:速度快、性能高

优势2:永久免费、商用免费

优势3:无任何时间/次数限制,放心使用

优势4:免费咨询服务

 

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 --  受影响的行数

 

【附注】:文章开头给出的下载示例,均已成功运行通过。但下载示例往往只包含“核心模板”内容,有些辅助内容需要自己建立/设置(比如:数据库创建、链接字符串设置、文件配置、路径设置、参数设定、等等...)。调式时若遇异常报错,请仔细阅读+理解本文。
技术交流群:微信扫描文末二维码(或添加微信:296894203),备注“进群”!

推荐阅读

  • .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数据库访问技术(续)
随时随地学软件编程-关注百度小程序和微信小程序
关于找一找教程网

本站文章仅代表作者观点,不代表本站立场,所有文章非营利性免费分享。
本站提供了软件编程、网站开发技术、服务器运维、人工智能等等IT技术文章,希望广大程序员努力学习,让我们用科技改变世界。
[.NET中大型项目开发必备(13)--DataAccess数据库访问技术(续)]http://www.zyiz.net/tech/detail-324015.html

赞(0)
关注微信小程序
程序员编程王-随时随地学编程

扫描二维码或查找【程序员编程王】

可以随时随地学编程啦!

技术文章导航 更多>