在C#中如何使用Dapper详解(译)

2020-01-05 09:25:28于丽

Dapper中的Execute()方法可以用于向数据库中插入,更新,删除数据。这个方法会返回一个整数,表示在执行查询时受到影响的行数。

下面的方法演示了如何用Dapper更新一条记录:


public int Update(Author author)
  {
   using (IDbConnection db = new SqlConnection(ConfigurationManager.ConnectionStrings["AdventureWorks"].ConnectionString))
   {
    string sqlQuery = "UPDATE Author SET FirstName = @FirstName, " +
    " LastName = @LastName “ + “WHERE Id = @Id";
    int rowsAffected = db.Execute(sqlQuery, author);
    return rowsAffected;
   }
  }

正如以上代码所看到的,Update()方法返回受影响的行数,也就是已更新的记录数,在本例中只会更新一条记录,所以方法成功时将会返回1.

存储过程在Dapper中的使用:

要使用Dapper处理存储过程,需在调用Query()或者Exectue()方法时显示地提到命令类型。下面的示例演示了如何使用Dapper来处理存储过程:


public List<Author> Read()
  {
   using (IDbConnection db = new SqlConnection(ConfigurationManager.ConnectionStrings["AdventureWorks"].ConnectionString))
   {
    string readSp = "GetAllAuthors";
    return db.Query<Author>(readSp, commandType: CommandType.StoredProcedure).ToList();
   }
  }

Dapper也支持事务,例如,如果需要我们可以使用事务操作,为此,你可以利用BeginTransaction() and EndTransaction()方法,就像通常在ADO.NET中处理事务一样,然后,您需要在BeginTransaction()和EndTransaction()方法调用中编写事务语句。

Dapper非常轻且使用起来非常简单,它不会为你生成SQL,但是可以很容易地将查询结果映射到POCOs(普通的旧CLR对象).最重要的是,你可以获得比EntityFrameWork更快的执行速度,事实上,几乎和ADO.NET一样。