Dapper的基本使用

Dapper是.NET下一個micro的ORM,它和Entity Framework或Nhibnate不一樣,屬於輕量級的,而且是半自動的。也就是說實體類都要本身寫。它沒有複雜的配置文件,一個單文件就能夠了。給出官方地址。數據庫

http://code.google.com/p/dapper-dot-net/app

我的以爲他很是好用,如今已經取代了原來的SqlHelper。優勢:ide

  1. 使用Dapper能夠自動進行對象映射!
  2. 輕量級,單文件。
  3. 支持多數據庫。
  4. Dapper原理經過Emit反射IDataReader的序列隊列,來快速的獲得和產生對象。

網上還有對Dapper的擴展類,這裏就不贅述了。下面只講下簡單的增刪改查、數據庫表間的對應關係和事務的應用。google

先給出實體類的關係:spa

 書和書評是1---n的關係。(沿用Entity Framework的實體類,virtual表示延遲加載,此處忽略)code

//
public class Book
    {
        public Book()
        {
            Reviews = new List<BookReview>();
        }
        public int Id { get; set; }
        public string Name { get; set; }
        public virtual List<BookReview> Reviews { get; set; }
        public override string ToString()
        {
            return string.Format("[{0}]------《{1}》", Id, Name);
        }
    }

//書評
 public class BookReview
    {
        public int Id { get; set; }
        public int BookId { get; set; }
        public virtual string Content { get; set; }
        public virtual Book AssoicationWithBook { get; set; }
        public override string ToString()
        {
            return string.Format("{0})--[{1}]\t\"{3}\"", Id, BookId, Content);
        }
    }
  • 基本的增刪改查操做

  因爲Dapper ORM的操做其實是對IDbConnection類的擴展,全部的方法都是該類的擴展方法。因此在使用前先實例化一個IDBConnection對象。orm

IDbConnection conn = new SqlConnection(connString);

Insert對象

Book book = new Book();
 book.Name="C#本質論";
 string query = "INSERT INTO Book(Name)VALUES(@name)";
//對對象進行操做
 conn.Execute(query, book);
//直接賦值操做
 conn.Execute(query, new {name = "C#本質論"});

updateblog

string query = "UPDATE Book SET  Name=@name WHERE id =@id";
 conn.Execute(query, book);

delete隊列

string query = "DELETE FROM Book WHERE id = @id";
conn.Execute(query, book);
conn.Execute(query, new { id = id });

query

string query = "SELECT * FROM Book";
//無參數查詢,返回列表,帶參數查詢和以前的參數賦值法相同。
 conn.Query<Book>(query).ToList();

 //返回單條信息
 string query = "SELECT * FROM Book WHERE id = @id";
 book = conn.Query<Book>(query, new { id = id }).SingleOrDefault();

數據庫表對應關係操做

//查詢圖書時,同時查找對應的書評,並存在List中。實現1--n的查詢操做
string query = "SELECT * FROM Book b LEFT JOIN BookReview br ON br.BookId = b.Id WHERE b.id = @id";
Book lookup = null;
//Query<TFirst, TSecond, TReturn>
 var b = conn.Query<Book, BookReview, Book>(query,
  (book, bookReview) =>
  {
     //掃描第一條記錄,判斷非空和非重複
    if (lookup == null || lookup.Id != book.Id)
      lookup = book;
    //書對應的書評非空,加入當前書的書評List中,最後把重複的書去掉。
    if (bookReview != null)
      lookup.Reviews.Add(bookReview);
     return lookup;
  }, new { id = id }).Distinct().SingleOrDefault();
return b;
//1--1操做 
BookReview br;
string query = "SELECT * FROM BookReview WHERE id = @id";
using (conn)
{
   br = conn.Query<BookReview, Book, BookReview>(query,
  (bookReview, book) =>
   {
    bookReview.AssoicationWithBook = book;
    return bookReview;
   }, new { id = id }).SingleOrDefault();
  return br;
}
using (conn)
{
//開始事務
IDbTransaction transaction = conn.BeginTransaction();
  try
  {
    string query = "DELETE FROM Book WHERE id = @id";
    string query2 = "DELETE FROM BookReview WHERE BookId = @BookId";
    conn.Execute(query2, new { BookId = id }, transaction, null, null);
    conn.Execute(query, new { id = id }, transaction, null, null);
    //提交事務
    transaction.Commit();
  }
  catch (Exception ex)
  {
    //出現異常,事務Rollback
    transaction.Rollback();
    throw new Exception(ex.Message);
  }
}
相關文章
相關標籤/搜索