文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

EF Core的CRUD(增删改查)基本操作

2024-04-02 19:55

关注

一、增加(C)

单笔增加

        //添加
        static void Add()
        {
            using (var db = new Entities())
            {
                Student stu1 = new Student
                {
                    Name = "李四",
                    Age = 19,
                    Adress = "合肥",
                    PhoneNumber = "13200000000"
                };

                //把实体对象附加到上下文
                db.Student.Add(stu1);
                //db.Entry(stu1).State=System.Data.Entity.EntityState.Added;  
                var res = db.SaveChanges();

                if (res > 0)
                {
                    Console.WriteLine("添加数据成功!");
                }
            }
        }

批量增加

  //批量处理
        static void AddBatch()
        {
            using (var db = new Entities())
            {
                for (int i = 1; i < 10; i++)
                {
                    var stu1 = new Student
                    {
                        Name = "Rimche" + i,
                        Age = 19 + i,
                        Adress = "合肥",
                        PhoneNumber = "1730000000" + i
                    };
                    db.Student.Add(stu1);
                }

                //可以进行其他操作

                db.SaveChanges();

            }
        }

二、查询

普通查询

        //查询
        static void Query()
        {
            using (var db = new Entities())
            {

                //根据ID进行查询
                var stu1 = db.Student.Find(2);
                var stu11 = db.Student.Where(x => x.Id == 1).FirstOrDefault();
                //根据年龄查找,多个结果时,返回第一个
                var stu2 = db.Student.Where(s=>s.Age==18).FirstOrDefault();

                Console.WriteLine(stu1.Name);
                Console.WriteLine(stu2.Name);

                Console.WriteLine("======延迟查询======");
                //根据条件,返回IQueryable,说明是延迟查询
                var query = db.Student.Where(s => s.Id > 3);
                foreach (var item in query)
                {
                    Console.WriteLine(item.Id + "\t" + item.Name);
                }

                //查询所有
                Console.WriteLine("======查询所有======");
                var queryall=db.Student.ToList();
                foreach (var item in queryall)
                {
                    Console.WriteLine(item.Id + "\t" + item.Name);
                }

            };
        }

分页查询

        //分页查询
       static void PagingQuery(int pageIndex,int pageSize)
        {
            using (var db=new Entities())
            {
                //分页一定要排序
                var query = db.Student.OrderBy(s=>s.Id).Skip((pageIndex -1)*pageSize).Take(pageSize).ToList();
                foreach (var item in query)
                {
                    Console.WriteLine(item.Id + "\t" + item.Name);
                }

            }
        }

三、更新

提供两种更新方式

        //更新
        static void Update()
        {
            using (var db =new Entities())
            {
                //方式一:官方推荐   只会修改需要修改字段
                Student stu = db.Student.Where(s => s.Id == 1).FirstOrDefault();
                stu.Name = "李时珍";
                db.SaveChanges();


                //方式二:修改所有字段
                Student stu1 = db.Student.Where(s => s.Id == 2).FirstOrDefault();
                stu1.Age = 10;
                db.Entry(stu1).State = System.Data.Entity.EntityState.Modified;
                db.SaveChanges();

            }
        }

四、删除

提供两种删除方式

        static void Delete()
        {
            using (var db = new Entities())
            {
                var stu = db.Student.Find(2);//也可以从数据库查询到
                //方式一
                //db.Student.Remove(stu);

                //方式二
                db.Entry(stu).State = System.Data.Entity.EntityState.Deleted;

                int result = db.SaveChanges();
                Console.WriteLine(result);

            }
        }

到此这篇关于EF Core增删改查CRUD的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持编程网。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯