- Java锁的逻辑(结合对象头和ObjectMonitor)
- 还在用饼状图?来瞧瞧这些炫酷的百分比可视化新图形(附代码实现)⛵
- 自动注册实体类到EntityFrameworkCore上下文,并适配ABP及ABPVNext
- 基于Sklearn机器学习代码实战
支持.Net/.Net Core/.Net Framework,可以部署在Docker, Windows, Linux, Mac.
。
由于该工具近来被广东省数个公司2B项目采用,且表现稳定,得到良好验证,故在此推荐出来.
此工具在IDataAccess接口中提供。 。
IDataAccess所在的命名空间是:DeveloperSharp.Framework.QueryEngine(需从NuGet引用DeveloperSharp包) 。
它主要提供了如下四大功能:
(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 Students2 = IDA.SqlExecute<stu>( " select * from t_Student where Id>@IdMin and Name like @LikeName " , new { IdMin = 2 , LikeName = " %周% " }); // 另一种写法1 var IdMin = IDA.CreateParameterInput( " IdMin " , DbType.Int32, 2 ); var LikeName = IDA.CreateParameterInput( " LikeName " , DbType.String, 50 , " %周% " ); var Students3 = IDA.SqlExecute<stu>( " select * from t_Student where Id>@IdMin and Name like @LikeName " , LikeName, IdMin); // 另一种写法2 var Students4 = 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字段名对应
注意:(1)DbType类型的命名空间是System.Data 。
(2) 若没有定义stu实体类,也可以用 dynamic 替代 。
。
【示例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 );
分页后获得的PagePiece对象中所包含的各类属性/参数,可参看这篇文章: 高效分页 。
。
【示例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 " ); // 修改数据(带参数) int affectedRows2 = IDA.SqlExecute( " insert into t_Student(Name,Age)values(@N,@A) " , new { N = " 孙悟空 " , A = 200 }); // 另一种写法 var NewAge = IDA.CreateParameterInput( " NewAge " , DbType.Int32, 200 ); var NewName = IDA.CreateParameterInput( " NewName " , DbType.String, 50 , " 孙悟空 " ); int affectedRows3 = IDA.SqlExecute( " insert into t_Student(Name,Age)values(@NewName,@NewAge) " , NewName, NewAge); // 完成事务 IDA.TransactionCommit(); } catch { // 回滚事务 IDA.TransactionRollBack(); }
。
【示例4:输出参数】 。
前面几个示例都只用到了“输入参数”,下面我们看看“输出参数”怎么使用,示例代码如下:
var op1 = IDA.CreateParameterOutput( " TotalCount " , DbType.Int32); // 此项为输出参数 var op2 = IDA.CreateParameterOutput( " MyName " , DbType.String, 50 ); // 此项为输出参数 // 以下sql语句混杂了多个“输入”与“输出”参数,注意看 IDA.SqlExecute( " insert into Friend(Birth,Name,height)values(@B,@N,@h); " + " select @TotalCount=count(*) from Friend; " + " select @MyName=Name from Friend where Id=@Id " , new { N = " 杨小伟 " , B = " 1999-02-28 12:03:45 " , h = 11.023 , Id = 2 }, op1, op2); int tc = Convert.ToInt32(op1.Value); string mn = op2.Value.ToString();
。
【示例5:存储过程】 。
最后,我们来谈谈如何调用存储过程。我们创建一个存储过程,它带有输入、输出、返回三种类型的参数,代码如下:
CREATE PROCEDURE Test5 @B as datetime , @N as nvarchar ( 50 ), @h as float , @TotalCount as int output, @MyName as nvarchar ( 50 ) output, @Id as int AS BEGIN insert into Friend(Birth,Name,height) values ( @B , @N , @h ); select @TotalCount = count ( * ) from Friend; select @MyName = Name from Friend where Id = @Id ; return @TotalCount + 100 ; END
调用该存储过程的示例代码如下:
var op1 = IDA.CreateParameterOutput( " TotalCount " , DbType.Int32); // 输出参数 var op2 = IDA.CreateParameterOutput( " MyName " , DbType.String, 50 ); // 输出参数 var op3 = IDA.CreateParameterReturn(); // 返回参数 IDA.SpExecute( " Test5 " , new { N = " 杨小伟 " , B = " 1999-02-28 12:03:45 " , h = 11.023 , Id = 2 }, op1, op2, op3); int tc = Convert.ToInt32(op1.Value); string mn = op2.Value.ToString(); int ret = Convert.ToInt32(op3.Value);
。
学习+灵活使用以上5个示例,就能满足几乎所有的数据操作需求,且操作十分简易.
。
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 <T> 声明:IEnumerable <T> SqlExecute<T>( string cmdText, object InputParams, params IDataParameter[] Params) where T : class , new () 用途:执行Sql语句(Select类) 参数:( 1 ) string cmdText -- Sql语句 ( 2 ) object InputParams -- 输入参数对象 ( 3 ) 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 -- 受影响的行数 SqlExecute 声明: int SqlExecute( string cmdText, object InputParams, params IDataParameter[] Params) 用途:执行Sql语句(Insert /Update/ Delete类) 参数:( 1 ) string cmdText -- Sql语句 ( 2 ) object InputParams -- 输入参数对象 ( 3 ) 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 <T> 声明:IEnumerable <T> SpExecute<T>( string cmdText, object InputParams, params IDataParameter[] Params) where T : class , new () 用途:执行Sp存储过程(Select类) 参数:( 1 ) string cmdText -- Sp存储过程名 ( 2 ) object InputParams -- 输入参数对象 ( 3 ) 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 -- 受影响的行数 SpExecute 声明: int SpExecute( string cmdText, object InputParams, params IDataParameter[] Params) 用途:执行Sp存储过程(Insert /Update/ Delete类) 参数:( 1 ) string cmdText -- Sp存储过程名 ( 2 ) object InputParams -- 输入参数对象 ( 3 ) params IDataParameter[] Params -- 参数组 返回: int -- 受影响的行数
原文链接: http://www.developersharp.cc/content13.html 。
。
【附注】:文中所有示例均已成功运行通过!技术交流/支持+更多精彩干货,请立刻关注下方公众号! 。
。
。
最后此篇关于.Net执行SQL/存储过程之易用轻量工具的文章就讲到这里了,如果你想了解更多关于.Net执行SQL/存储过程之易用轻量工具的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
创建使用.NET框架的asp.net页面时,访问该页面的客户端是否需要在其计算机上安装.NET框架? IE。用户访问www.fakesite.com/default.aspx,如果他们没有安装框架,他
我阅读了很多不同的博客和 StackOverflow 问题,试图找到我的问题的答案,但最后我找不到任何东西,所以我想自己问这个问题。 我正在构建一个应用程序,其中有一个长时间运行的工作线程,它执行一些
已锁定。这个问题及其答案是locked因为这个问题是题外话,但却具有历史意义。目前不接受新的答案或互动。 我一直想知道为什么微软为这样一个伟大的平台选择了一个如此奇怪的、对搜索引擎不友好的名称。他们就
.Net Framework .Net .NET Standard的区别 1、.NET Framework 在未来.NET Framework或许成为过去时,目前还是有很多地方在使用的。这一套
如果有选择的话,您会走哪条路? ASP.NET Webforms + ASP.NET AJAX 或 ASP.NET MVC + JavaScript Framework of your Choice
我有一个 Web 服务,它通过专用连接通过 https 使用第三方 Web 服务,我应用了 ServicePointManager.ServerCertificateValidationCallbac
为什么我应该选择ASP.NET Web Application (.NET Framework)而不是ASP.NET Core Web Application (.NET Framework)? 我在
我在网络上没有找到任何关于包含 .NET Standard、.NET Core 和 .NET Framework 项目的 .NET 解决方案的公认命名约定。 就我而言,我们在 .NET 框架项目中有以
.NET Compact 是 .NET 的完美子集吗? 假设我考虑了屏幕大小和其他限制并避免了 .NET Compact 不支持的类和方法,或者 .NET Compact 是一个不同且不兼容的 GUI
我已经阅读了所有我能找到的关于 connectionManagement 中的 maxconnection 设置的文章:即 http://support.microsoft.com/kb/821268
我现在正在使用asp.net mvc,想知道使用内置的Json或 Json.Net哪个是更好的选择,但我不确定一个人是否比另一个人有优势。 另外,如果我确实选择沿用Json.Net的路线,那么我应该选
在 Visual Studio 中,您至少可以创建三种不同类型的类库: 类库(.NET Framework) 类库(.NET 标准) 类库(.NET Core) 虽然第一个是我们多年来一直使用的,但我
.NET 和 ASP.NET 之间有什么区别?它们有什么关系? 最佳答案 ASP.Net 基于 .Net 框架构建,提供有关 Web 开发的附加功能。 你可以去看看wikipedia article
在安装更高版本(3.0)之前,我需要安装.net框架1.1和2.0吗?或者单独安装 3.0 框架就足够了,并为在早期框架版本上编写的软件提供支持?谢谢 ,丽然 最佳答案 不,您不必安装以前的框架。 我
我正在开发一个项目,人们可以“更新”类别,例如更改类别的名称。我收到以下消息 This is called after clicking update 按钮 with the SQL statemen
.NET 类 System.Net.CookieContainer 线程安全吗? --更新:交 key 答复-- 是否有任何方法可以确保异步请求期间修改的变量(即 HttpWebRequest.Coo
我正在使用 JScript.NET 在我编写的 C# WinForms 应用程序中编写脚本。它工作得很好,但我只是尝试在脚本中放置一些异常处理,但我无法弄清楚如何判断我的 C# 代码抛出了哪种类型的异
我需要你的帮助, 比如我有一个小数类型的变量,我想这样取整。 例如 3.0 = 3 3.1 = 4 3.2 = 4 3.3 = 4 3.4 = 4 3.5 = 4 3.6 = 4 3.7 = 4 3.
我使用过这样的代码:http://msdn.microsoft.com/en-us/library/dw70f090.aspx在 ASP.NET 中工作之前访问数据库(2-3 年前)。我没有意识到我正
自 ConfigurationManager .NET Standard 中不存在,检索正在执行的程序集的应用程序设置的最佳方法是什么,无论是 web.config或 appSettings.{env
我是一名优秀的程序员,十分优秀!