code first从入门到伪精通
新入职一家公司,虽然之前也用ef,但是方式不一样,之前用的db,现在用代码先行的code,基于现有公司基本项目框架都是用的code,所以一步登顶,从最实战的角度去操作code,心颤的很,废话不多说,开始重要环节:
1,重复的一些安装操作就不再多说了,百度都有,我只讲我遇到的一些个问题点
2,通常我们进行操作迁移的时候,是不是基本都是Enable-Migrations这样,但是如果碰到这样的呢
咋办呢,其实也很简单,英语好的同学自行翻译,英语不好的同学浏览器地址栏fanyi.baidu.com,其实出来的意思都是一样的,多个上下文,其实这就是实战当中碰到的,因为一般的只会有一个,但是项目为了应对不同的需求会用到多个上下文关联一个或多个数据库,
所以解决起来也简单,要用哪个就复制哪个出来执行就完事了(最后面这个)
3, 这个似曾相识吧,其实就是上面的命令已经成功,接着执行下面的命令了
好了,说完了,就这样!
4,并没有,还有一个最重要的问题怎么更改decimal等浮点型数字的精度呢,刚开始也一直桌面在之前的实体里面加头,跟加字段约束一样的,但是太复杂又不符合项目书写规范,找了很久,后面在一个叫老饭饭的大佬的指导下,我顺势找到了方 法,也符合了项目的书写规范,具体实现也很简单,不废话,上代码
能看明白不,就是在你需要用的的上下文里面重写一个方法,调用ef相关的东西,然后去更改字段的精度和长度,然后再执行上面的操作,直到看到数据库字段的精度和长度改变为止,
还有一种方式是可以先执行Add-Migration "版本名称"生成一个空的Migrations日志,然后再在里面写入需要更改的字段,像这样
然后再执行Update-Database命令,如果执行以后数据库字段还是没有改变,可上数据库查询表__MigrationHistory,删除最新的自己执行的那条(些)操作的记录然后继续Update-Database命令,直到数据库字段更新为止!
另附上一个大佬写的比较标准的文章供参考https://www.cnblogs.com/libingql/p/3330880.html
完毕等下班!