zoukankan      html  css  js  c++  java
  • EF简单增删改查

    一. 主要内容

    1. 数据持久层框架:EF,NHibernate,ibaties(半开放的)。

    2. 对象关系映射。

    3. 生成外键对象。

    4. T4模板。(VS里面需要装T4 Editor插件。)

    5. EF上下文(EF容器)->.Context.cs。

    6. EF简单的增删改查。

    查询:利用部分类的特性重写方法来进行方法的扩展。

    修改(SQL Serrver Profiler跟踪):

    先查询,再修改,再保存更改。

    7. 延迟加载(延时查询、按需加载)和即时查询。

    延迟加载的用途一:

    SQL语句条件不确定,所以不能立即进行查询,延迟加载以确定所有条件完成,等开始用的时候才开始查询。

    延迟加载的用途二(外键延迟):

    对于外键实体属性的延迟加载。

    按需加载的缺点:

    每次调用外键实体时,都会去查询数据库(EF小优化:相同的外键实体只查询一次),这时候用即使加载比较好。

    8. 延迟加载二视频里面的:数据库改变,则EF实体不会对应改变,可以选择从数据库更新模型。

    9. EF的连接查询

    include(“User”),通过include方法,可以告诉EF连接查询哪个外键属性。

    10. EF容器(EF数据上下文)

           修改时,不用Attach方式,使用Entry方式。

    11. 批处理

    12. MODELFirst(实体优先)

    13.  EF补充:Select方法能自动生成inner join语句。

    二. 源代码

      1 using System;
      2 using System.Collections.Generic;
      3 using System.Data.Entity;
      4 using System.Data.Entity.Infrastructure;
      5 using System.Linq;
      6 using System.Text;
      7 using System.Threading.Tasks;
      8 
      9 namespace EFTest
     10 {
     11     class Program
     12     {
     13         static LeaveWordBoardEntities db = new LeaveWordBoardEntities();
     14         static void Main(string[] args)
     15         {
     16             Querry();
     17         }
     18 
     19         static Program()
     20         {
     21             //取消自动验证所跟踪的实体
     22             db.Configuration.ValidateOnSaveEnabled = false;
     23         }
     24 
     25         #region 1.0 新增
     26         /// <summary>
     27         /// 新增
     28         /// </summary>
     29         static void Add()
     30         {
     31             User uObj = new User()
     32             {
     33                 uName = "HUOAA11",
     34                 uLoginName = "a11",
     35                 uPwd = "a11",
     36                 uIsDel = false,
     37                 uAddTime = DateTime.Now
     38             };
     39             //两种不同的新增方式:本质上都是把该对象标记为新增,让EF上下文来执行新增操作。
     40             //db.Users.Add(uObj);
     41             DbEntityEntry<User> entry = db.Entry<User>(uObj);
     42             entry.State = EntityState.Added;
     43             db.SaveChanges();
     44             Console.WriteLine("新增成功!");
     45         }
     46         #endregion
     47 
     48         #region 2.0 简单查询
     49         /// <summary>
     50         /// 简单查询
     51         /// </summary>
     52         static void Querry()
     53         {
     54             //1.1 延时查询一
     55             //DbQuery<User> i = db.Users.Where(u => u.uLoginName == "HUOTENG").OrderBy(u => u.uId) as DbQuery<User>;
     56             //User user01 = i.FirstOrDefault();
     57             //Console.WriteLine(user01.uName);
     58 
     59             //1.2 延时查询二:针对于外键实体
     60             //对于外键属性而言,EF会用这个外键属性时才去查询对应的表。
     61             //IQueryable<UsersAddress> addrs = db.UsersAddresses.Where(a=>a.udUId==2);//真实返回的DBQuery对象,以接口方式返回
     62             ////a. 此时只查询了地址表
     63             //UsersAddress addr01 = addrs.FirstOrDefault();
     64             ////b. 查询地址对应的用户表
     65             //Console.WriteLine(addr01.User.uName); 
     66             //c. 按需加载的缺点:会为每次调用外键实体时,都会去查询数据库。
     67             //IQueryable<UsersAddress> addrs = db.UsersAddresses;
     68             //foreach (UsersAddress add in addrs)
     69             //{
     70             //    Console.WriteLine(add.udAddress+":userName="+add.User.uName);
     71             //}
     72             //1.3 连接查询,生成innner join
     73             //IQueryable<UsersAddress> addrs = db.UsersAddresses.Include("User");
     74             //foreach (UsersAddress add in addrs)
     75             //{
     76             //    Console.WriteLine(add.udAddress + ":userName=" + add.User.uName);
     77             //}
     78             //IQueryable<Msg> msgs = db.Msgs.Include("User").Include("User1");
     79             //foreach (Msg msg in msgs)
     80             //{
     81             //    Console.WriteLine(msg.mId + "," + msg.User.uName + "," + msg.User1.uName + "," + msg.mMsg);
     82             //}
     83             //1.4 另一种方式的连接查询Select
     84             var addrs = db.UsersAddresses.Where(a => a.udUId == 1).Select(a => new { aId = a.udUId, aAddress = a.udAddress, aUserName = a.User.uName }).ToList();
     85 
     86 
     87             //2. 变相的即时查询
     88             //List<User> list = db.Users.Where(u => u.uName == "HUOAA").ToList();
     89             //list.ForEach(u => Console.WriteLine(u.ToString()));
     90         }
     91         #endregion
     92 
     93         #region 3.0 先查询再修改
     94         /// <summary>
     95         /// 先查询再修改
     96         /// </summary>
     97         static void Edit()
     98         {
     99             User user = db.Users.Where(u => u.uId == 3).FirstOrDefault();
    100             user.uName = "nihaoa2";
    101             db.SaveChanges();
    102             Console.WriteLine("修改成功!");
    103         }
    104         #endregion
    105 
    106         #region 4.0 直接修改
    107         /// <summary>
    108         /// 直接修改
    109         /// </summary>
    110         static void Edit2()
    111         {
    112             ////1. 查询出一个要修改的对象,此时返回的是一个User类的代理类对象
    113             //User user = db.Users.Where(u => u.uId == 2).FirstOrDefault();
    114             //Console.WriteLine("修改前:"+user.ToString());
    115             ////2. 如果被修改,会在EF上下文容器中标记该属性为已修改
    116             //user.uName = "刘德华";
    117             ////3. EF上下文进行检查,找到标记修改的属性,生成对应的UPDATE语句进行修改
    118             //db.SaveChanges();
    119             //Console.WriteLine("修改后:"+user.ToString());
    120 
    121             //Entry方式修改
    122             User user = new User() { uId = 2, uName = "小白", uLoginName = "xiaobai", uPwd = "13", uAddTime = DateTime.Now, uIsDel = false };
    123             DbEntityEntry<User> entry = db.Entry<User>(user);
    124             entry.State = EntityState.Unchanged;
    125             entry.Property("uName").IsModified = true;
    126             db.SaveChanges();
    127             Console.WriteLine("修改成功!");
    128         }
    129         #endregion
    130 
    131         #region 5.0 删除
    132         /// <summary>
    133         /// 删除
    134         /// </summary>
    135         static void Del()
    136         {
    137             User u = new User() { uId = 4 };
    138             db.Users.Attach(u);
    139             db.Users.Remove(u);
    140             /*
    141              * 也可以用Entry来附加和修改
    142              * DbEntityEntry<User> entry = db.Entry<User>(u);
    143              * entry.State = EntityState.Deleted;
    144              */
    145             db.SaveChanges();
    146         }
    147         #endregion
    148 
    149         #region 6.0 批处理
    150         /// <summary>
    151         /// 6.0 批处理
    152         /// </summary>
    153         static void SaveBatched()
    154         {
    155             //6.1 新增
    156             //User u1 = new User()
    157             //{
    158             //    uName = "asd",
    159             //    uLoginName = "c",
    160             //    uPwd = "asdf",
    161             //    uIsDel = false,
    162             //    uAddTime = DateTime.Now
    163             //};
    164             //db.Users.Add(u1);
    165 
    166             //6.2 修改
    167             User u2 = new User() { uId = 8, uName = "小黑" };
    168             DbEntityEntry<User> entry = db.Entry<User>(u2);
    169             entry.State = EntityState.Unchanged;
    170             entry.Property("uName").IsModified = true;
    171 
    172             //6.3 删除
    173             //User u3 = new User() { uId=7};
    174             //db.Users.Attach(u3);
    175             //db.Users.Remove(u3);
    176 
    177             //6.4 进行统一的批处理
    178             db.SaveChanges();
    179             Console.WriteLine("批处理完成!");
    180         }
    181         #endregion
    182 
    183         #region 7.0 批处理添加大量数据
    184         /// <summary>
    185         /// 批处理添加大量数据
    186         /// </summary>
    187         static void BatchAdd()
    188         {
    189             for (int i = 0; i < 50; i++)
    190             {
    191                 User u = new User()
    192                 {
    193                     uName = "qwer" + i,
    194                     uLoginName = "qwer" + i,
    195                     uPwd = "qwer" + i,
    196                     uIsDel = true,
    197                     uAddTime = DateTime.Now
    198                 };
    199                 db.Users.Add(u);
    200             }
    201             db.SaveChanges();
    202             Console.WriteLine("批处理完成!~");
    203         }
    204         #endregion
    205     }
    206 }
    View Code
  • 相关阅读:
    oracle数据库
    Filter过滤器
    Json
    监听器
    Ajax
    2018年5月14日java
    EL表达式&JSTL
    JSP
    2018年5月9日JAVA-servlet02
    如何解决写脚手架过程中遇到请求github的项目接口中出现API rate limit exceeded for的问题。
  • 原文地址:https://www.cnblogs.com/HuoAA/p/4115012.html
Copyright © 2011-2022 走看看