dapper 批量删除、新增、修改说明

Dapper是什么?

  Dapper是一款.Net平台简单(Simple)的对象映射库,并且Dapper拥有着“微型ORM之王”的称号。

  就速度而言与手写ADO.NET SqlDateReader相同。

  ORM是Object Relational Mapper的缩写,代表着数据库与编程语言之间的映射。

  简单来说就是使用Entity Framework、NHibernate 来处理大数据访问及关系映射,未免有点杀鸡用牛刀,那么Dapper会是不错的选择。

1、Dapper基本用法

通过NuGet安装:Dapper包,如果要进行mysql连接还需要安装Mysql.Data包

2、数据库连接配置

<connectionStrings> 
  <add name="MysqlServer" connectionString="Database=用数据库名称;Data Source=IP;Port=端口; User Id=用户名;Password=密码;Charset=utf8mb4;TreatTinyAsBoolean=false;" /> //Mysql

  <add name="LinqConnection" connectionString="Data Source=IP;Initial Catalog=数据库名称; User ID=用户名;Password=密码" providerName="System.Data.SqlClient"/> //sql
</connectionStrings>

3、dapper 数据库连接方法

Mysql连接方法:

复制代码
public class DapperService 
{

  public static MySqlConnection MySqlConnection()
  {
     string mysqlConnectionStr = ConfigurationManager.ConnectionStrings["MysqlServer"].ToString();
     var connection = new MySqlConnection(mysqlConnectionStr); connection.Open();
    return connection;
  }
}
复制代码

mssql连接方法:

复制代码
public class DapperService { 

  public static SqlConnection MySqlConnection()
  {

    string mysqlConnectionStr =ConfigurationManager.ConnectionStrings["LinqConnection"].ToString();
    var connection = new SqlConnection(mysqlConnectionStr);
    connection.Open();
    return connection;
  }
}
复制代码

4、新增方法(单体、批量)

单体:

复制代码
public ActionResult GetDapper(CarModel carModel)
{
  try
  {
    using (IDbConnection conn = DapperService.MySqlConnection())
   {
      int result = conn.Execute("insert into UserInfo(UserTel,UserName,UserPwd) values (@UserTel,@UserName,@UserPwd)", carModel);
    }
    return Json("success");
  }
  catch(Exception e)
  {
   return Json("failed");
  }
}
复制代码

批量:

复制代码
public ActionResult GetDapper(List<CarModel> carModel) 
{
 try
  {
    using (IDbConnection conn = DapperService.MySqlConnection())
    {
      int result = conn.Execute("insert into UserInfo(UserTel,UserName,UserPwd) values(@UserTel,@UserName,@UserPwd)", carModel);
    }
    return Json("success");
  }
  catch(Exception e)
  {
    return Json("failed");
  }
}
复制代码

5、删除方法(单体、批量)

单体:

public static int Delete(CarModel carModel) 
{   
using (IDbConnection conn = DapperService.MySqlConnection())   {    return conn.Execute("delete from UserInfo where id=@ID", carModel);   } }

批量:

public static int Delete(List<CarModel> carModel) 
{ 
  using (IDbConnection conn = DapperService.MySqlConnection()) 
  { 
    return conn.Execute("delete from UserInfo where id=@ID", carModel); 
  } 
}

6、更新方法(单体、批量)

单体:

public static int Update(CarModel carModel) 
{ 
  using (IDbConnection conn = DapperService.MySqlConnection()) 
  {
     return conn.Execute("update UserInfo set name=@name where id=@ID", carModel);
   } 
}

批量:

public static int Update(List<CarModel> carModel) 
{ 
  using (IDbConnection conn = DapperService.MySqlConnection())
   { 
    return conn.Execute("update UserInfo set name=@name where id=@ID", carModel); 
  } 
}

7、查询

无参查询

public static List<CarModel> Query() 
{ 
  using (IDbConnection conn = DapperService.MySqlConnection()) 
  { 
    return conn.Query<CarModel>("select * from UserInfo ").ToList();
  } }

有参查询

public static Person Query(CarModel carModel) 
{ 
  using (IDbConnection conn = DapperService.MySqlConnection()) 
  { 
    return conn.Query<CarModel>("select * from UserInfo where id=@ID",carModel).SingleOrDefault(); 
  } 
}

8、Dapper的复杂操作

In操作

public static List<CarModel> QueryIn() 
{ 
  using (IDbConnection conn = DapperService.MySqlConnection()) 
  { 
    var sql = "select * from UserInfo where id in @ids"; 
     return conn.Query<CarModel>(sql, new { ids = new int[2] { 1, 2 }, }).ToList(); 
  } 
}
public static List<CarModel> QueryIn(int[] ids) 
{ 
  using (IDbConnection conn = DapperService.MySqlConnection()) 
  { 
    var sql = "select * from UserInfo where id in @ids";
    return conn.Query<CarModel>(sql, new { ids }).ToList(); 
  } 
}

9、多语句操作

复制代码
public ActionResult QueryMultiple() 
{ 
  try 
  {  
    using (IDbConnection conn = DapperService.MySqlConnection()) 
    { 
      var sql= "select * from Person; select * from UserInfo"; 
      var multiReader = conn.QueryMultiple(sql); 
      var personList = multiReader.Read<Person>(); 
      var bookList = multiReader.Read<CarModel>(); multiReader.Dispose(); 
    } 
    return Json("success"); 
  } 
  catch(Exception e) 
  { 
    return Json("failed"); 
  } 
}
复制代码

 

posted @   大空白纸  阅读(2633)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
点击右上角即可分享
微信分享提示