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 ...
随机推荐
- Django的模板继承
来看一个例子 我们有一个订单的页面和购物车的页面,比如下面的截图,我的购物车的页面和订单的页面只有圆圈中的截图的内容不一样 所以我们的订单的html页面和购物车的html业务的html几乎都是一致的 ...
- Python requests 使用心得
最近在用requests写一些项目,遇见了一些问题,百度了很多,有些都不太好使,最后看了下requestsAPI文档,才明白了很多,最后项目趋于稳定.看来学东西还是API文档比较权威啊~ 问题场景 项 ...
- NSThread 在主线操作的三个方法
- (void)createNSThread444{ UIImage *image = [UIImage imageNamed:@"图片名字"]; /** 1 performSel ...
- Redis阅读目录
一.Redis简介 点击链接查看:https://www.cnblogs.com/hwlong/p/9325986.html 二.Redis安装及基本配置 点击链接查看:https://www.cnb ...
- 什么是Shell、Shell脚本
Shell本身是一个用C语言编写的程序,它是用户使用Linux的桥梁.Shell既是一种命令语言,又是一种程序设计语言.作为命令语言,它交互式地解释和执行用户输入的命令:作为程序设计语言,它定义了各种 ...
- Web开发者工具下载
登录微信公众号:https://mp.weixin.qq.com
- Vagrant WinNFSd
Vagrant WinNFSd Manage and adds support for NFS on Windows. Supported Platforms As of version 1.0.6 ...
- IntelliJ IDEA 2017版 SpringBoot的核心配置详解
Spring Boot的核心 (1)Spring Boot的项目一般都会有*Application的入口类,入口类中会有main方法,这是一个标准的Java应用程序的入口方法. (2)@Spri ...
- UVa 12118 nspector's Dilemma (构造+DFS+欧拉回路)
题意:给定n个点,e条边和每条边的长度t,每两个点之间都有路相连,让你求一条最短的路经过这e条边. 析:刚开始想到要判连通,然后把相应的几块加起来,但是,第二个样例就不过,后来一想,那么有欧拉回路的还 ...
- 继承方法-->最终模式
function inherit(Target,Origin){ function F(){}; F.prototype = Origin.prototype; // Targrt.prototype ...