工作中的问题与学习
.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 就是对某个文件进行撤销了