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实用精要(清华大学出版社--吕高旭著)

 

posted @ 2018-01-31 23:18  蜗牛的礼物  阅读(174)  评论(0编辑  收藏  举报