Entity Framework 的小实例:在项目中添加一个实体类,并做插入操作
admin
2023-05-25 03:41:11
0

Entity Framework 的小实例:在项目中添加一个实体类,并做插入操作

1>. 创建一个控制台程序
2>. 添加一个 ADO.NET实体数据模型,选择对应的数据库与表(StudentModel.edmx)
3>. 控件台代码

Entity Framework 的小实例:在项目中添加一个实体类,并做插入操作

        static void Main(string[] args)
        {            // 创建一个网关接口,TestData是数据库名
            TestDataEntities td = new TestDataEntities();            
            // 创建一个实体对象,Student是表映射过来的对象,将其赋值
            Student st1 = new Student();
            st1.StudentID = "s4";
            st1.StudentName = "test1";
            st1.Age = 20;            // 将实体对象添加到网关接口,插入操作
            td.Student.AddObject(st1);            // 网关保存并改变
            td.SaveChanges();

            Console.WriteLine("添加成功!");
        }

Entity Framework 的小实例:在项目中添加一个实体类,并做插入操作

如上 StudentModel.edmx 是生成的实体模型就是 映射表,里面包含对象于表的定义

Entity Framework 增删改查 操作


1>. 基本同上
2>. 控件台代码

Entity Framework 的小实例:在项目中添加一个实体类,并做插入操作

    class Program
    {        // 创建一个网关接口,TestData是数据库名,静态方法只能调用静态类
        static TestDataEntities stuEntities = new TestDataEntities();        static void Main(string[] args)
        {            // 创建一个实体对象,Student是表映射过来的对象,将其赋值
            Student st1 = new Student();
            st1.StudentID = "s4";
            st1.StudentName = "小明";
            st1.Age = 20;            //InsertStu(st1);            //DeleteStu("s4");            //Student stu2 = FindStudentByID("s4");            //stu2.StudentName = "小明";            //UpdateStu(stu2);            //Console.WriteLine(stu2.StudentName);
            

        }        // 添加操作
        public static void InsertStu(Student stu)
        {            // 将实体对象添加到网关接口,插入操作
            stuEntities.Student.AddObject(stu);            // 网关保存并改变
            stuEntities.SaveChanges();
            Console.WriteLine("添加成功!ID:"+stu.StudentID);
        }        // 删除操作
        public static void DeleteStu(string ID)
        {
            Student stu = FindStudentByID(ID);
            stuEntities.Student.DeleteObject(stu);
            stuEntities.SaveChanges();
            Console.WriteLine("删除成功!ID:" + stu.StudentID);

        }        // 更新操作
        public static void UpdateStu(Student stu)
        {            // 其中 var 为 IQueryable类型,继承IEnumerable            // 继承IEnumerable的类都能实现 foreach
            var student = from s in stuEntities.Student                          where s.StudentID == stu.StudentID                          select s;            // 得到student集合里面的单一实体
            var oldStu = student.SingleOrDefault();            // 修改对应的属性值
            oldStu.StudentName = stu.StudentName;
            oldStu.Age = stu.Age;            
            // 保存修改
            stuEntities.SaveChanges();
            Console.WriteLine("更新成功!ID:" + stu.StudentID);
        }    // 更新数据 新方法
        public bool UpdateEntity(MvcHotel.Model.Customer entity)
        {            bool result = false;            // 添加对象到上下文
            he.Attach(entity);            // 改变新加入对象的状态,设置为 已修改
            he.ObjectStateManager.ChangeObjectState(entity, System.Data.EntityState.Modified);            if (he.SaveChanges() > 0)
            {
                result = true;
            }            return result;
        }        // 查询操作
        public static Student FindStudentByID(string ID)
        {        // 方式1: Linq to EF            // 根据ID查询Student,并得到集合中的单一实体
            var stu = (from s in stuEntities.Student                       where s.StudentID == ID                       select s).SingleOrDefault();        // 方式2: Entity SQL
            string sql = "select Value c from TestDataEntities.Student as c ";
            ObjectQuery query = stuEntities.CreateQuery(sql);
            ObjectResult results = query.Execute(MergeOption.NoTracking);            //return stu;
            return query.SingleOrDefault();
        }
    }

Entity Framework 的小实例:在项目中添加一个实体类,并做插入操作

EF中操作数据库的网关

ObjectContext封装 .NET Framework 和数据库之间的连接。此类用作“创建”、“读取”、“更新”和“删除”操作的网关
ObjectContext 类为主类,用于与作为对象(这些对象为 EDM 中定义的实体类型的实例)的数据进行交互
ObjectContext 类的实例封装以下内容:
a> 到数据库的连接,以 EntityConnection 对象的形式封装。
b> 描述该模型的元数据,以 MetadataWorkspace 对象的形式封装
c> 用于管理缓存中持久保存的对象的 ObjectStateManager 对象


相关内容

热门资讯

CIA下场了,古巴会变天吗? 5月14日,美国中情局(CIA)局长约翰·拉特克利夫罕见访问古巴,转达了总统特朗普的明确要求:古巴必...
“超常规举措推进办案”“绝不失... ‍‍据《青海日报》消息,5月18日上午,青海召开全省群众身边不正之风和腐败问题集中整治二季度调度会,...
湖北雨滂沱,他看着妻子消失在洪... 5月17日晚,湖南常德市石门县壶瓶山镇,小优(化名)一家听着外面的暴雨声,几乎一夜未眠。雨从当天上午...
中央气象台发布双预警!广西、广... 5月20日6时,中央气象台发布暴雨蓝色预警和沙尘暴蓝色预警。中央气象台5月20日6时发布暴雨蓝色预警...
欧迈德取得四通阀门管道内壁抛光... 国家知识产权局信息显示,潍坊欧迈德工贸有限公司取得一项名为“一种四通阀门管道内壁抛光设备”的专利,授...
帮无人机“黑飞”?小心直接触犯... 近年来,无人机的应用日趋广泛,但闯入禁飞区、突破限高等“黑飞”行为也时有发生。前段时间,浙江衢州警方...
赣州冷库设备厂家该如何甄别 近年来,赣州作为赣南地区经济发展核心节点,依托特色农业产业基础与区域物流枢纽定位,生鲜仓储、食品加工...
国安部:境外间谍控制路由器窃密 近期,国家安全机关工作发现,境外间谍情报机关利用我国境内路由器充当“跳板”,以“钓鱼邮件”为掩护,定...
中方大使:中国台湾地区不能参加... 中国台湾地区不能参加世卫大会,原则明确、法理清楚(大使随笔)贾桂德《人民日报》(2026年05月20...
试图扼住“数字咽喉”?伊朗打出... 新华社北京5月19日电(记者柳伟建 王储 胡冠)日前,素有全球“能源咽喉”之称的霍尔木兹海峡,又以“...