EF总结--模型创建和数据的增删改查

EF的创建方式有三种:

  • DataBaseFirst

新建项-ADO.NET实体数据模型-从数据库生成

  • ModelFirst

新建项-ADO.NET实体数据模型-空模型,在设计器中设计实体和它们之间的关系,之后右击选择从模型生成数据库。

  • CodeFirst

通过写代码的方式,创建实体,上下文,数据库也是通过写代码生成。

LinQ To EF进行增删改查

增:

            //实例化上下文
            departmentEntities dbcontext = new departmentEntities();
            //添加
            emp myemp = new emp();
            myemp.depid = 2;
            myemp.empid = 2;
            myemp.empname = "kitty";
            //附加到上下文
            dbcontext.emp.add(myemp);
            //更新到数据库
            dbcontext.savechanges();

修改:

            //修改,通常是所有属性都赋值
            myemp.depID = 2;
            myemp.empID = 2;
            myemp.empName = "Hello Kitty";
            dbcontext.Entry<emp>(myemp).State = EntityState.Modified;
            dbcontext.SaveChanges();

先查询后修改:

            //查询后更改,不用附加(Entry)到上下文
            var e = dbcontext.emp.First();
            e.empName = "abc";
            dbcontext.SaveChanges();

删除:

            var myemp = dbcontext.emp.Find(7);
            //删除,传一个主键就可以
            dbcontext.Entry<emp>(myemp).State = EntityState.Deleted;
            dbcontext.SaveChanges();

查询:

            //查询 原始 不用LinQ
            List<emp> myemplist = new List<emp>();
            foreach (var item in dbcontext.emp)
            {
                if (item.empID > 2)
                {
                    myemplist.Add(item);
                    Console.WriteLine(item.empName + "\n");
                }
            }
            foreach (var myemp in myemplist)
            {
                Console.WriteLine(myemp.empName);
            }
            //查询 LinQ
            var result = (from b in dbcontext.emp
                          where b.empID > 2
                          select b);
            foreach (var item in result)
            {
                Console.WriteLine(item.empName + "\n");
            }
时间: 2024-10-09 03:32:31

EF总结--模型创建和数据的增删改查的相关文章

linq的创建 和 数据的增删改查

1.linq创建之前,一定要在sql做好数据表的主外键关系. 2.linq文件是以.dbml结尾,一般一个数据库的名字就是一个linq的名字 3,以实例来演示增删改查 数据库的名字为linq,里面有两个表Users(UserName,Password,Sex,NickName,Birthday,Nation)和Nation(NationCode,NationName) (1)创建名为linq的linq. 创建完之后啥也不用改,如果需要在重新封装类和数据扩展,那就想以前重新建立Users和User

【黑马Android】(04)数据库的创建和sql语句增删改查/LinearLayout展示列表数据/ListView的使用和BaseAdater/内容提供者创建

数据库的创建和sql语句增删改查 1. 加载驱动. 2. 连接数据库. 3. 操作数据库. 创建表: create table person( _id integer primary key, name varchar(20), age integer ); 添加: insert into person(name, age) values('lisi', 19); 删除: delete from person where _id = 1; 修改: update person set name =

yii中数据的"增删改查"相关工作!(此文比较乱,需细看)

使用findByPk()根据数据表主键查询的是对象,不需要使用foreach()循环出来 但是使用findall()和find()查询的是对象类型的数组需要使用foreach()循环出来 ======================================= public function getMinLimit () { $sql = "..."; $result = yii::app()->db->createCommand($sql); $query = $r

ios CoreData框架的使用,对上下文数据的增删改查,表与表之间的关联,1对多,1对1,谓词查询,多表连接

这里是只是代码,因为博客插入图片效果不是很好,我自己写的总结比较详细,有兴趣的朋友可以在评论里留下邮箱,我收到后会发给大家. 转载注明出处,重视原创者的劳动成果,谢谢! - (void)viewDidLoad { [super viewDidLoad]; [self _creatTable];//插入数据 //    [self _query];// 查询数据 // KVC很霸道,即使readonly通过kvc也可赋值,kvo精华 //    Book * book = [[Book alloc

Rhythmk 学习 Hibernate 01 - maven 创建Hibernate 项目之 增删改查入门

1.环境: Maven :3.1.1 开发工具:Spring Tool Suite 数据库 : Mysql  5.6 2.项目文件结构 文件代码: 2.1 .pom.xml <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.ap

使用MVC5+Entity Framework6的Code First模式创建数据库并实现增删改查功能

此处采用VS2017+SqlServer数据库 一.创建项目并引用dll: 1.创建一个MVC项目 2.采用Nuget安装EF6.1.3 二.创建Model 在models文件夹中,建立相应的model文件,这里建立的class名,就是数据库里表的名字.        在这里面,可以建立表之间的关系,本次将建立Course(课程).Student(学生).StuCourse(课程学生关系)来作为一个Demo [Table("t_course")]   //可以通过Attribute的形

Node.js + MySQL 实现数据的增删改查

通过完成一个 todo 应用展示 Node.js + MySQL 增删改查的功能.这里后台使用 Koa 及其相应的一些中间件作为 server 提供服务. 初始化项目 $ mkdir node-crud && cd $_ $ yarn init -y && npx gitignore node 上面的命令创建了一个空文件夹 node-crud,进入之后初始化一个 package.json 以及创建 .gitignore 文件. 安装 Koa 并创建 app.js 以启动一个

数据的增删改查(三层)

进行数据操作必然少了对数据的增删改查,用代码生成器生成的代码不是那么满意!方便在今后使用,这里就主要写“数据访问层(Dal)” 注:这里由于是用于用于测试时,临时建的数据库用于测试使用,在实际使用过程中些许改点参数就可以使用了 /// <summary> /// 是否存在该记录 /// </summary> public bool Exists(long Id) { string sql = "select count(*) Name from t_temp where

数据库开发基础-SQl Server 控制数据库的服务+数据库的创建与管理(增删改查)

控制数据库的服务: 方法一: 1.Windows+R 打开运行  打开cmd 2.输入net start MSSQLserver 启动数据库服务 输入net stop MSSQLserver 关闭数据库服务 输入net pause MSSQLserver 暂停数据库服务 输入net continue MSSQLserver 继续数据库服务 数据库的创建与管理(增删改查): 打开SQL Server 2008 方法二: 1.打开控制面板→管理工具→服务 2.右键进行选择 数据库的创建与管理: 打开