工作中的问题与学习

.net 中的 Entity Framework 实体框架

普通查询

两种方式举例说明
[基本查询] 查询所有的

//表达式形式
 List<students> = form s in db.Student
                 select s;
//lambda表达式形式
List<students>   = db.Student

条件查询 加入条件进行查询

///普通形式
List<students> = (form s in db.Student
                   where s.Name == "张三"
                select s).ToList();
//lambda表达式形式
 List<students>  = db.Student.Where(t => t.Nmae == "张三").ToList();

排序查询和分页查询

linq方式

List<student>= (from s in db.Student 
    orderby s.Name
    select s).Skip(0).Take(5).ToList(); 

//lambda表达式方式

    List<Student>= db.Studenet.OrderBy(s => s.Name).Skip(0).Take(5);

注:没有排序是不能进行分页查询的

聚合查询

查总数

    var num = db.Student.Count();

查最小ID

    var minId = db.Student.Min(s => s.Id);

连接查询

  var Studetns= from sin db. Student
    join c in db. Class
    on s.ClassId equals s.ID
  select s;

EF的增删改操作

增加
创建一个新的对象

Student stu =new Student("张三""三年级""男"...)
db.Student.Add(stu);
db.SaveChanges();

删除

Student stu = db.Student.Find(Id);
db.Remove(stu);
db.SaveChanges();

修改

 Student stu = db.Student.Find(Id);
 stu.Name = "李四";
 db.Entry(stu).State = EntityState.Modified;
 db.SaveChanges();

注:不能两个 db对象操作同一个实体对象,也不能同一个db操作两个实体对象,举例(1、主键赋值后保存 2、将控制层db查到的实体对象传入业务层,重新创建db对象操作,会产生错误)

代码规范

linq
1、使用find查询的数据,先进行null判断
2、使用FirstOrDefault查询的数据,先进行null判断
4、使用where查询的数据,先使用count()==0判断
5、字典取值前使用ContainsKey(key)判断
6、list、array遍历时,要判null和count=0
7、使用TryParse,不使用Parse
8、字符串使用前使用string.IsNullEmpty判断
9、Equlas判断前,要判断null
10、对象取值前,先判断null(操作对象的方法或者实体、字段前先判断是否为空)
11、as转换,先判断null
12、数组、list取值时要判断下标

常用git命令

git 命令

开发时,对于本地的项目中修改不做保存操作(或代码改崩),可以用到Git pull的强制覆盖,具体代码如下:

远程仓库覆盖本地仓库

git fetch --all
git reset --hard origin/master
git pull //可以省略
git fetch 指令是下载远程仓库最新内容,不做合并
git reset 指令把HEAD指向master最新版本

撤回add添加的内容

git reset HEAD 如果后面什么都不跟的话 就是上一次add 里面的全部撤销了
git reset HEAD XXX/XXX/XXX.java 就是对某个文件进行撤销了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值