加入收藏 | 设为首页 | 会员中心 | 我要投稿 甘南站长网 (https://www.0941zz.com/)- 科技、行业物联网、开发、云计算、云管理!
当前位置: 首页 > 综合聚焦 > 程序设计 > 正文

.Net上有什么轻量工具执行SQL存储过程?

发布时间:2024-05-19 08:32:34 所属栏目:程序设计 来源:DaWei
导读:   这篇文章将为大家详细讲解有关“.Net上有什么轻量工具执行SQL存储过程?”的知识,下文有详细的介绍,小编觉得挺实用的,对大家学习或工作或许有帮助,因此分享给大家做个参考

  这篇文章将为大家详细讲解有关“.Net上有什么轻量工具执行SQL存储过程?”的知识,下文有详细的介绍,小编觉得挺实用的,对大家学习或工作或许有帮助,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

  目录

  正文

  【示例1:查询】

  【示例2:分页】

  【示例3:增/删/改】

  【示例4:输出参数】

  【示例5:存储过程】

  正文

  由于该工具近来被广东省数个公司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("select * from t_Student");

  //查询多数据(带参数)

  var Students2 = IDA.SqlExecute("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("select * from t_Student where Id>@IdMin and Name like @LikeName", LikeName, IdMin);

  //另一种写法2

  var Students4 = IDA.SqlExecute("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("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

  声明:IEnumerable SqlExecute(string cmdText, params IDataParameter[] Params) where T : class, new()

  用途:执行Sql语句(Select类)

  参数:(1)string cmdText -- Sql语句

  (2)params IDataParameter[] Params -- 参数组

  返回:IEnumerable -- 多数据结果集

  SqlExecute

  声明:IEnumerable SqlExecute(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 -- 多数据结果集

  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

  声明:IEnumerable SpExecute(string cmdText, params IDataParameter[] Params) where T : class, new()

  用途:执行Sp存储过程(Select类)

  参数:(1)string cmdText -- Sp存储过程名

  (2)params IDataParameter[] Params -- 参数组

  返回:IEnumerable -- 多数据结果集

  SpExecute

  声明:IEnumerable SpExecute(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 -- 多数据结果集

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

  现在大家对于.Net上有什么轻量工具执行SQL存储过程?的内容应该都有一定的认识了吧,希望这篇能对大家有所帮助。

(编辑:甘南站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章