第一步:创建上下文对象

using(var db = new Entities())
{
//数据操作
}

新增

    UserInfo user = new UserInfo()
{
UserName = "zhangsan1",
UserPass = "123123"
};
db.UserInfo.Add(user);

删除

    user = new UserInfo()
{
UserID = 4, //根据主键删除
UserName = "zhangsan",
UserPass = "12312311111"
};
db.Entry<UserInfo>(user).State = System.Data.Entity.EntityState.Deleted;

说明:此例中虽然指定了UserName和UserPass属性值,但是EF执行的时候只会根据主键UserID生成查询条件,所以只需要制定UserID即可。

删除 方法2

    user = new UserInfo()
{
UserID = 13 //根据主键删除
};
//Attach的实体事先不能已经在内存中,否则上下文会追踪到两个相同键名的实体
db.UserInfo.Attach(user);//将对象添加到EF管理容器中 ObjectStateManager
db.UserInfo.Remove(user);//将对象包装类状态标识为删除

删除 先查询-再删除

    //先加载整个实体 再删除 执行了2次sql 效率略低
using (var db = new Entities())
{
var user = (from v in db.UserInfo
where v.UserID == 14
select v).Single();
db.UserInfo.Remove(user);
db.SaveChanges();
}

修改

    user = new UserInfo()
{
UserID = 12,
UserName = "zhangsan",
UserPass = "987654"
};
db.Entry<UserInfo>(user).State = System.Data.Entity.EntityState.Modified;

修改单个属性

    user = new UserInfo()
{
UserID = 12,
UserName = "zhangsan"
};
db.UserInfo.Attach(user);
db.Entry<UserInfo>(user).Property<string>(v => v.UserName).IsModified = true;

说明:将UserID=12的用户名称改为 zhangsan

修改单个实体 先查询-再修改

    using (var db = new Entities())
{
var user = (from v in db.UserInfo
where v.UserName == "zhangsan"
select v).Single();
user.UserPass = "123456";
db.SaveChanges();
}

说明:将用户名为 zhangsan的用户 密码修改为:123456

查询所有实体

    var users = db.UserInfo;
foreach (var v in users)
{
ObjectDumper.Write(v);//打印实体
}

查询单个实体 主键查询

    using (var db = new Entities())
{
var user = db.UserInfo.Find(12);
ObjectDumper.Write(user);
}

说明:查询UserID=12的用户

备注:所有增删改操作都需要调用 db.SaveChanges() 方法,才能更新到数据库。

完整案例:

using(var db = new Entities())
{
//新增
UserInfo user = new UserInfo()
{
UserName = "zhangsan1",
UserPass = "123123"
};
db.UserInfo.Add(user); //删除
user = new UserInfo()
{
UserID = 4, //根据主键删除
UserName = "zhangsan",
UserPass = "12312311111"
};
db.Entry<UserInfo>(user).State = System.Data.Entity.EntityState.Deleted; //删除 方法2
user = new UserInfo()
{
UserID = 13 //根据主键删除
};
//Attach的实体事先不能已经在内存中,否则上下文会追踪到两个相同键名的实体
db.UserInfo.Attach(user);//将对象添加到EF管理容器中 ObjectStateManager
db.UserInfo.Remove(user);//将对象包装类状态标识为删除 //删除单个实体
//先加载整个实体 再删除 执行了2次sql 效率略低
user = (from v in db.UserInfo
where v.UserID == 14
select v).Single();
db.UserInfo.Remove(user);
db.SaveChanges(); //修改
user = new UserInfo()
{
UserID = 12,
UserName = "zhangsan",
UserPass = "987654"
};
db.Entry<UserInfo>(user).State = System.Data.Entity.EntityState.Modified; //修改单个属性
db.UserInfo.Attach(user);
db.Entry<UserInfo>(user).Property<string>(v => v.UserName).IsModified = true; //修改单个实体
user = (from v in db.UserInfo
where v.UserName == "zhangsan"
select v).Single();
user.UserPass = "abcd";
db.SaveChanges(); //查询遍历
var users = db.UserInfo;
foreach (var v in users)
{
ObjectDumper.Write(v);
} //查询单个实体
user = db.UserInfo.Find(12);
ObjectDumper.Write(user); //保存更新到数据库
db.SaveChanges();
}

最新文章

  1. java机器学习工具包
  2. 安装eclipse插件时出现问题
  3. git bash下的选择、复制、粘贴
  4. python 时间处理(time和datetime介绍)
  5. Zend Framework 入门(1)—快速上手
  6. 【Python】python读取文件操作mysql
  7. php删除html标签的三种解决方法
  8. SQLite入门与分析(四)---Page Cache之事务处理(2)
  9. PT100运算放大器电路
  10. 注册DLL,Unregister DLL
  11. python实现简单表单校验框架
  12. mac android studio 更新sdk的解决方案
  13. iOS_应用程序的生命周期
  14. [LOJ3084][GXOI/GZOI2019]宝牌一大堆——DP
  15. ios APNS注册失败 本地push
  16. win8 tiles风格标签插件jquery.wordbox.js
  17. Codeforces.888G.Xor-MST(Borůvka算法求MST 贪心 Trie)
  18. 解决 docker 报错: Error starting daemon: error initializing graphdriver: backing file system is unsupported for this graph driver
  19. go陷阱
  20. MySQL utilities介绍&amp;出现 No module named utilities

热门文章

  1. SQL Tuning Health-Check Script (SQLHC) (文档 ID 1366133.1)
  2. Java_Day6(上)
  3. 安装CPULimit到Linux(源码)
  4. layui的跳转链接实现分页low
  5. 一个简易git服务器的搭建
  6. 实现Windows数据更新
  7. JS绑定事件处理函数及处理流程
  8. [转]TCP/IP 协议基础(一)
  9. 【Unity|C#】基础篇(21)——常用类
  10. java下的slf4j