ADO.Net 和 Entity Framework 机制(一)
首先,创建一个新数据库EF,在里面创建一个dbo.Product
数据大致如下:
----ADO.Net----
创建一个C#控制台
代码如下:
static void Main(string[] args) { string connString = @"data source=.;initial catalog=EF;user id=sa;password=sa;MultipleActiveResultSets=True;"; SqlConnection conn = new SqlConnection(connString); SqlCommand cmd = new SqlCommand("Select * from Product",conn); conn.Open(); SqlDataAdapter da = new SqlDataAdapter(cmd); DataTable data = new DataTable(); da.Fill(data); conn.Close(); da.Dispose(); Console.WriteLine("上平数据项数:{0}\t",data.Rows.Count); Console.WriteLine("编号\t定价\t\t类型\t名称\t"); foreach (DataRow row in data.Rows) { int id = int.Parse(row["Id"].ToString()); string name = row["Name"].ToString(); decimal price = decimal.Parse(row["Price"].ToString()); string category = row["Category"].ToString(); Console.WriteLine("{0}\t定价:{1}\t{2}\t{3}", id, price, category, name); } Console.Read(); }
运行结果:
----Entity Framework----
创建一个C#控制台
代码如下:
static void Main(string[] args) { EFManager conn = new EFManager(); IEnumerable<Product> pList = conn.GetProducts(); foreach (Product p in pList) { Console.WriteLine("{0}\t定价:{1}\t{2}\t{3}", p.Id, p.Price, p.Category, p.Name); } Console.Read(); }
创建一个Product类
public class Product { public int Id { get; set; } public string Name { get; set; } public string Category { get; set; } public decimal Price { get; set; } }
创建一个EFManager(获取数据的处理类)
public class EFManager { public IEnumerable<Product> GetProducts() { //创建数据库链接 string connString = @"data source=.;initial catalog=EF;user id=sa;password=sa;MultipleActiveResultSets=True;"; SqlConnection conn = new SqlConnection(connString); SqlCommand cmd = new SqlCommand("Select * from Product", conn); //开启数据链接 conn.Open(); //执行查询语句获取数据 SqlDataAdapter da = new SqlDataAdapter(cmd); DataTable data = new DataTable(); da.Fill(data); //关闭数据链接 conn.Close(); //释放 da.Dispose(); List<Product> list = new List<Product>(); //循环数据,进行数据转换 foreach (DataRow row in data.Rows) { list.Add(this.TProduct(row)); } return list; } //创建ProductList public Product TProduct(DataRow row) { Product p = new Product { Id = int.Parse(row["Id"].ToString()), Name = row["Name"].ToString(), Price = decimal.Parse(row["Price"].ToString()), Category = row["Category"].ToString() }; return p; } }
运行结果:
思考:
ADO.Net 和 Entity Framework
区别在于 一个 Class,ADO.Net 可以直接链接数据库,使用SQL查询语句直接获取数据,但转换数据的时候需要 注意数据的类型;
Entity Framework 则创建一个 数据类,然后 获取数据之后 并进行 数据的类型转换,多了一步
参考:EntityFramework实用精要(清华大学出版社--吕高旭著)