EF使用CodeFirst创建数据库和表

EF支持三种实体模型:Code First,Model First和DB First,分别表示代码优先,模型优先和数据库优先。目前就个人来说使用CodeFirst最多,对此相对比较熟悉,先写下Code First的使用吧。

那什么是Code First代码优先呢?通俗来说,就是先写好代码,建立好模型,程序员只需关注对象间的关系,即可在数据库生成相应的表,基本上做到了与数据库的完全分离。为啥说基本上呢,其实是有道理的。

那Code First有什么优点呢?我们为什么要用它?

(1)如上面所说,程序员不需要关心数据库里面的情况,只需处理好类和对象的关系就好,其余的事情不用咱们管了。

(2)应该是便于测试吧,因为使用DBFirst的话会生成EDMX文件,它与数据库绑定性较强,个人觉得略麻烦。

(3)微软主推CodeFirst吧,这应该算是一个不错的工具。

那么接下来咱试试看!

1、先创建一个项目,啥都行,我习惯性的弄了一个控制台,先添加一个文件夹,再右键添加--新建项,选择ADO.NET实体数据模型,为项目命名,点击添加。


2、在实体数据模型向导中选择空的CodeFirst模型,官方也给出了说明,可以生成数据库。


3、系统会自动生成一个类,注意,我们需要自动生成的模型都需要继承自DbContext,可以看到,微软已经给了我们很多提示了,比如:我们需要自己配置连接数据库的字符串;我们要创建的类都需要在MyEntity实体类中添加DbSet。不得不说微软在这些地方做的还是很不错的,一目了然!


4、然后我新建了两个类,UserInfo和Roles。这里需要根据提示引入相应的命名空间。并且需要用Key为自己的表指定主键,用Table为类指定表名,StringLength为字段定义长度.........



这时需要按照微软提供的模板将这两个类添加到DbSet。这里的“name=MyEntity”表示使用名字为MyEntity的字符串连接数据库,如果只写"MyEntity"的话,表示直接创建名字为MyEntity的数据库。


5、接下来就可以撸一段代码了。


到这里即将信息输入完成了,但是还差一步,细心的小伙伴应该想到了,都没有数据库,这添加到哪去啊。因此下面这一步也是不可少的。

6、在App.Config中,有一个名字为MyEntity的配置字符串,这里我们需要修改成我们想要的服务器名称、数据库名和登录信息。


点击运行后就会生成相应的数据库还有表啦。


表已经生成了,数据也添加进去了。


通过上面的例子可以看到,使用空的CodeFirst模型设计数据库是很方便的,我们不需要关注数据库的使用方法,只需按照套路建实体类,声明字段,然后操作其对象,就可以生成数据库和表啦。因此这种方式是很适合数据库的迁移的,只需把程序拷到另一台电脑上运行一下就OK了。


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/272376.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

从头学Qt Quick(3)-- 用QML写一个简单的颜色选择器

先看一下效果图: 实现功能:点击不同的色块可以改变文字的颜色。 实现步骤: 一、创建一个默认的Qt Quick工程: 二、添加文件Cell.qml 这一步主要是为了实现一个自定义的组件,这个组件就是我们看到的那个色块,很明显定义…

LED闪烁和流水灯,调试教程,在线仿真器的使用

常用的延时方法&#xff1a; 软件延时&#xff08;使用简单但是浪费CPU资源&#xff09;、定时器延时&#xff08;不浪费CPU资源&#xff09;&#xff0c;本次先使用软件延时。 LED全亮代码&#xff1a; #include<reg52.h> //引用51的头文件 void main() {P10; }整体代…

docker中命令docker images

docker images 用于查看本地已下载的镜像 REPOSITORY 镜像仓库 TAG 镜像标签 IMAGE ID 镜像ID CREATED 镜像创建时间 SIZE 镜像大小

用VS2017开发安卓应用

vs2017自安装以后就没怎么打开过&#xff0c;虽然12出的时候用10&#xff0c;15出的时候用13&#xff0c;17出的时候用15&#xff0c;但我依然坚持不用也装上再说的理念。1、vs2017开发IOS和Android安装所必不可少的&#xff0c;uwp和net core也顺便装了吧&#xff0c;作为一个…

算法题11 字符串的所有对称子串

题目 给定一个字符串&#xff0c;求其中所有的对称子串 分析 对称字符串无非两种情况&#xff0c;一是以1个字符为中心对称&#xff0c;如"abcba",一是完全对称&#xff0c;如"abccba"。对于字符串对称的判断&#xff0c;从内往外查找比较方便 代码  1 in…

C51蜂鸣器和数码管动静态显示

蜂鸣器代码 #include<reg52.h> #include<intrins.h>#define uint unsigned int #define uchar unsigned charsbit beepP2^3; uchar temp; void delay(void) //误差 -0.000000000023us {unsigned char a,b;for(b221;b>0;b--)for(a207;a>0;a--); } void mai…

MYSQL 定时自动执行任务

MYSQL5.1开始支持EVENT功能&#xff0c;类似Oracle和MSSQL的定时任务job功能。有了这个功能之后我们就可以让MySQL自动的执行存储过程来实现数据汇总等功能了&#xff0c;不用像以前哪样手动操作完成了。下面我们来测试下&#xff0c;在MYSQL中如何自动执行指定存储过程&#x…

docker删除本地已下载的镜像

1&#xff1a;首先用 docker images 查看一下本地已下载的镜像 2&#xff1a;使用 docker rmi --force IMAGED ID 删除镜像

51单片机独立键盘和矩阵键盘

独立键盘代码&#xff1a; #include<reg52.h> #include<intrins.h>#define uint unsigned int #define uchar unsigned charsbit beepP2^3; sbit DUAN P2^6;//数码管段选 sbit WEIP2^7; //数码管位选sbit key_s2 P3^0;//独立按键s2 sbit key_s3 P3^1;//独立按键s3…

SQLSERVER数据库内存占用高的解决方法

远程登录服务器时发现程序执行时特别卡&#xff0c;利用任务管理器查看了下系统资源使用情况&#xff0c;监视一段时间后发现CPU占用不大&#xff0c;但是内存占用量居高不下&#xff0c;然后发现是Sqlserver.exe这个服务占用内存很大&#xff0c;达到了近2G服务器配置的8G内存…

docker ps 和docker ps -a

列出正在运行的容器 docker ps 显示所有的容器&#xff0c;包括未运行的 docker ps -a

51单片机8*8点阵屏、取模软件的使用

取模软件网盘提取 链接&#xff1a;https://pan.baidu.com/s/1YYQo_tZNCXlo9uWVbtsNdg 提取码&#xff1a;jfbr 74HC595芯片原理图&#xff1a; 两片595芯片级联驱动点阵屏只需要三个IO口&#xff0c;串行入&#xff08;一次只能传一个数据&#xff0c;S_CLK&#xff09;并行…

(Object-C)学习笔记(一)--开发环境配置和与c语言的区别

博主是大三快要实习的学生&#xff0c;作为软件技术专业的我认真的考虑了一下出路&#xff0c;认为去干起点低低java不如花点钱选择iOS。正好我也对iOS很感兴趣&#xff0c;虽然我赶不上08年之后的那一段互联网热潮&#xff0c;但是这一段时间互联网仍旧稳步发展&#xff0c;而…

MVC下实现LayUI分页的Demo

1、后台获取数据示例public JsonResult GetPageNew(int page,int pagesize){var list _context.ArticleInfo.Skip(page).Take(pagesize).ToList();return Json(new { data list, total list.Count });}2、View视图<head><meta charset"UTF-8"><tit…

使用docker安装elasticsearch

下载elasticsearch6.4.0的docker镜像: docker pull elasticsearch:6.4.0 修改虚拟内存区域大小&#xff0c;否则会因为过小而无法启动: sysctl -w vm.max_map_count262144 使用docker命令启动 docker run -p 9200:9200 -p 9300:9300 --name elasticsearch \ -e "discov…

中断系统详解、外部中断

51单片机各个引脚功能 IO口引脚&#xff1a; 中断系统的主要功能&#xff1a;处理随机突发事件 中断系统结构&#xff1a; 什么是中断系统&#xff1a; 数据的输入/输出传送方式&#xff1a; 中断传送方式特点&#xff1a; 51系统允许的5个中断源&#xff1a; 51单片…

android app两种调试方法

方法一&#xff1a; 1、使用apktool的-d选项反编译apk文件 java -jar apktool.jar d -d target.apk -o output 2、在AndroidManifest的application节点中添加 android:debuggable"true" 3、在入口点的类的onCreate中添加如下代码等待调试 invoke-static{}, La…

2019温馨的元旦祝福语 2019元旦祝福语大全!收藏备用!

打开日历新日子&#xff0c;2019年展开新篇子&#xff0c;送你祝福金盒子&#xff0c;包含吉祥话段子&#xff0c;金银财宝满屋子&#xff0c;升官发财有路子&#xff0c;聪明赛过孙猴子&#xff0c;拥有致富鬼点子&#xff0c;娶妻生子抱孩子&#xff0c;没事天天找乐子&#…

定时/计数器(定时和计数的功能)、定时器中断

定时/计数器实现功能&#xff1a; &#xff08;1&#xff09;定时功能&#xff1a; 定时/计数器说明&#xff08;最高单次计时时间是71毫秒65535*1.085us&#xff0c;1.085us是机器周期&#xff09;&#xff1a; 使用51定时/计数器步骤: 定时/计算器控制寄存器&#xff1a;…

jquery.cookie中的操作之与换肤

jquery.cookie.js的插件&#xff0c;插件的源代码如下&#xff1a; /*** Cookie plugin** Copyright (c) 2006 Klaus Hartl (stilbuero.de)* Dual licensed under the MIT and GPL licenses:* http://www.opensource.org/licenses/mit-license.php* http://www.gnu.org/license…