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一样。










