EF学习笔记-1 EF增删改查
首次接触Entity FrameWork,就感觉非常棒。它节省了我们以前写SQL语句的过程,同时也让我们更加的理解面向对象的编程思想。最近学习了EF的增删改查的过程,下面给大家分享使用EF对增删改查时如何处理的。
第一步:创建自定义的DbContext来连接自己的数据库。
public class DataBaseContext : DbContext
{
public DataBaseContext() : base("name=SQLCONN")
{
}
public DbSet<Model.Entities.StudentEntity> StudentEntities { get; set; }
}
1、新增操作
我们会根据前台传过来的实体信息对数据库的表进行新增操作。对于以前使用SQL语句的方式,我们会写很长的SQL语句来实现。而对于EF来说,只需要几句简单的代码就可以搞定。
public void Insert(StudentEntity studentEntity)
{
if(studentEntity == null)
throw new ArgumentNullException(nameof(studentEntity));
using (DataBaseContext dataBaseContext = new DataBaseContext())
{
dataBaseContext.Set<StudentEntity>().Add(studentEntity);
dataBaseContext.SaveChanges();
}
}
2、删除操作
对于删除来说,通常我们使用软删除来操作。毕竟数据库中数据尽量不要真的删除了。那么数据表中经常会设置一个IsDeleted字段。那么我们只需要给IsDeleted字段赋值,重新再SaveChanges就可以了。
public void Delete(int id)
{
if(id == 0)
throw new ArgumentNullException(nameof(id));
using (DataBaseContext dataBaseContext = new DataBaseContext())
{
StudentEntity studentEntity = dataBaseContext.Set<StudentEntity>().FirstOrDefault(t => t.Id == id);
if (studentEntity != null) studentEntity.Isdeleted = true;
dataBaseContext.SaveChanges();
}
}
3、修改操作
通过刚才删除操作的例子,我们可以知道删除其实也就是修改方式的一种。我们只是对其中的一个字段进行修改,然后在进行SaveChanges操作。那么对于修改操作,也是一样的思想。不同的是修改操作会根据前台传过来的实体信息来给需要修改的字段赋值或者实际场景的业务来进行修改。
public void Update(StudentEntity studentEntity)
{
if (studentEntity == null)
throw new ArgumentNullException(nameof(studentEntity));
using (DataBaseContext dataBaseContext = new DataBaseContext())
{
StudentEntity student = dataBaseContext.Set<StudentEntity>().FirstOrDefault(t => t.Id == studentEntity.Id);
if (student != null)
{
student.StuName = studentEntity.StuName;
student.StuNo = studentEntity.StuNo;
student.StuSex = studentEntity.StuSex;
student.Grade = studentEntity.Grade;
}
dataBaseContext.SaveChanges();
}
}
我们可以看到,不论是修改还是删除,我们都会先从数据库中查询出对应的信息,然后再做对应的修改赋值操作,最后调用SaveChanges方法。
备注:所有增删改过程都需要调用SaveChanges方法,这样才能更新到数据库中。
4、查询操作
对于查询来说,一般会有查询所有实体信息和根据主键查询单个实体信息。
查询所有实体
public List<StudentEntity> GetList()
{
using (DataBaseContext dataBaseContext = new DataBaseContext())
{
List<StudentEntity> studentEntities = dataBaseContext.Set<StudentEntity>().ToList();
return studentEntities;
}
}
主键查询单个实体
public StudentEntity GetEntity(int id)
{
if (id == 0)
throw new ArgumentNullException(nameof(id));
using (DataBaseContext dataBaseContext = new DataBaseContext())
{
StudentEntity studentEntity = dataBaseContext.Set<StudentEntity>().FirstOrDefault(t => t.Id == id);
return studentEntity;
}
}
完整案例
public class StudentService
{
public List<StudentEntity> GetList(string stuName, string stuNo)
{
using (DataBaseContext dataBaseContext = new DataBaseContext())
{
List<StudentEntity> studentEntities;
if (!string.IsNullOrEmpty(stuName))
{
studentEntities = dataBaseContext.Set<StudentEntity>().Where(t => t.StuName == stuName).ToList();
}
else if (!string.IsNullOrEmpty(stuNo))
{
studentEntities = dataBaseContext.Set<StudentEntity>().Where(t => t.StuNo == stuNo).ToList();
}
else
{
studentEntities = dataBaseContext.Set<StudentEntity>().ToList();
}
return studentEntities;
}
}
public void Insert(StudentEntity studentEntity)
{
if(studentEntity == null)
throw new ArgumentNullException(nameof(studentEntity));
using (DataBaseContext dataBaseContext = new DataBaseContext())
{
dataBaseContext.Set<StudentEntity>().Add(studentEntity);
dataBaseContext.SaveChanges();
}
}
public void Update(StudentEntity studentEntity)
{
if (studentEntity == null)
throw new ArgumentNullException(nameof(studentEntity));
using (DataBaseContext dataBaseContext = new DataBaseContext())
{
StudentEntity student = dataBaseContext.Set<StudentEntity>().FirstOrDefault(t => t.Id == studentEntity.Id);
if (student != null)
{
student.StuName = studentEntity.StuName;
student.StuNo = studentEntity.StuNo;
student.StuSex = studentEntity.StuSex;
student.Grade = studentEntity.Grade;
}
dataBaseContext.SaveChanges();
}
}
public void Delete(int id)
{
if(id == 0)
throw new ArgumentNullException(nameof(id));
using (DataBaseContext dataBaseContext = new DataBaseContext())
{
StudentEntity studentEntity = dataBaseContext.Set<StudentEntity>().FirstOrDefault(t => t.Id == id);
if (studentEntity != null) studentEntity.Isdeleted = true;
dataBaseContext.SaveChanges();
}
}
public StudentEntity GetEntity(int id)
{
if (id == 0)
throw new ArgumentNullException(nameof(id));
using (DataBaseContext dataBaseContext = new DataBaseContext())
{
StudentEntity studentEntity = dataBaseContext.Set<StudentEntity>().FirstOrDefault(t => t.Id == id);
return studentEntity;
}
}
public List<StudentEntity> GetList()
{
using (DataBaseContext dataBaseContext = new DataBaseContext())
{
List<StudentEntity> studentEntities = dataBaseContext.Set<StudentEntity>().ToList();
return studentEntities;
}
}
}
有不对的地方请各位批评指正,互相学习!
EF学习笔记-1 EF增删改查的更多相关文章
- 【JAVAWEB学习笔记】20_增删改查
今天主要是利用三层架构操作数据库进行增删查改操作. 主要是编写代码为主. 附图: 前台和后台 商品的展示 修改商品
- HTML5+ 学习笔记3 storage.增删改查
//插入N条数据 function setItemFun( id ) { //循环插入100调数据 var dataNum = new Number(id); for ( var i=0; i< ...
- Python学习笔记-列表的增删改查
- [学习笔记] Oracle基础增删改查用法
查询 select *|列名|表达式 from 表名 where 条件 order by 列名 select t.* from STUDENT.STUINFO t where t.stuname = ...
- python学习之-成员信息增删改查
python学习之-成员信息增删改查 主要实现了成员信息的增加,修改,查询,和删除功能,写着玩玩,在写的过程中,遇到的问题,旧新成员信息数据的合并,手机号和邮箱的验证,#!/usr/bin/env p ...
- EF学习笔记-2 EF之支持复杂类型的实现
使用过.NET的小伙伴们知道,在我们的实体模型中,除了一些简单模型外,还有一些复杂类型,如几个简单的类型组合而成的类型:而EF除了在实现基本的增删改查之外,也支持复杂类型的实现. 那么如何手动构造复杂 ...
- hibernate系列笔记(1)---Hibernate增删改查
Hibernate增删改查 1.首先我们要知道什么是Hibernate Hibernate是一个轻量级的ORMapping对象.主要用来实现Java和数据库表之间的映射,除此之外还提供数据查询和数据获 ...
- JDBC基础学习(一)—JDBC的增删改查
一.数据的持久化 持久化(persistence): 把数据保存到可掉电式存储设备中以供之后使用.大多数情况下,数据持久化意味着将内存中的数据保存到硬盘上加以固化,而持久化的实现过程大多通过各 ...
- mybatis学习(五)——增删改查及自增主键的获取
一.mybatis的增删改查 1.修改hotelMapper接口 package com.pjf.mybatis.dao; import com.pjf.mybatis.po.Hotel; publi ...
随机推荐
- 【校招面试 之 C/C++】第18题 C++ 中的隐式转换以及explicit关键字
1.什么是隐式转换: 众所周知,C++的基本类型中并非完全的对立,部分数据类型之间是可以进行隐式转换的. 所谓隐式转换,是指不需要用户干预,编译器私下进行的类型转换行为.很多时候用户可能都不知道进行了 ...
- 在控制台远程连接mysql数据库时,出现ERROR 2049 (HY000)错误
问题的原因是,你本地的数据库版本过高,而远程的数据库版本低. 解决方法:在连接时加上 --skip-secure-auth 参数就可以了. mysql -h主机 -u用户名 -p密码 --skip- ...
- Linux系统 SecureCRT SecureFX 注册破解方法
1.创建脚本文件crack-binary.sh,内容如下: #!/bin/sh cd $1 cat SecureCRT | od -A n -v -t x1 | tr -d ' \n ...
- 2018年这些UI设计趋势正在流行,跟上必拿高薪!
数字设计领域和时尚圈是一样的,总会有各种各样的趋势让人眼花缭乱.无论是用户界面的视觉元素,还是用户体验的细节,总有许多值得说道的新玩法和新方向.就目前来看,UI设计的大趋势是更加大胆新颖的视觉设计,通 ...
- Executor(一)ExecutorService 线程池
Executor(一)ExecutorService 线程池 本篇主要涉及到的是 java.util.concurrent 包中的 ExecutorService.ExecutorService 就是 ...
- 2018.10.19 NOIP训练 变化的序列(线性dp)
传送门 f[i][j]f[i][j]f[i][j]表示后iii个对答案贡献有jjj个a的方案数. 可以发现最后a,ba,ba,b的总个数一定是n∗(n−1)/2n*(n-1)/2n∗(n−1)/2 因 ...
- Django入门与实践-第24章:我的账户视图(完结)
http://127.0.0.1:8000/settings/account/ #好的,那么,这部分将是我们最后的一个视图.之后,我们将专心来改进现有功能. #accounts/views.py fr ...
- android 蓝牙通讯编程 备忘
1.启动App后: 判断->蓝牙是否打开(所有功能必须在打牙打开的情况下才能用) 已打开: 启动代码中的蓝牙通讯Service 未打开: 发布 打开蓝牙意图(系统),根据Activity返回进场 ...
- 1024 Hello World
哈哈,原来今天是程序员的节日啊,快乐咯,可是今天好冷好冷~~
- C++之new/delete/malloc/free详解
主要内容: 1. C语言中的函数malloc和free 2. C++中的运算符new和delete 3. new/delete与malloc/free之间的联系和区别 4. C/C++程序的内 ...