MVC+EF 入门教程(二)
一、前沿
为了使以后项目分开,所以我会添加3个类库。用于存储 实体、数据库迁移、服务。这种思路是源于我使用的一个框架 ABP.有兴趣的您,可以去研究和使用这个框架。
二、修改本地连接
在项目中,找到 Web.config 在里面添加如下代码:
<!--SqlServer数据库连接-->
<connectionStrings>
<add name="Default" connectionString="Server=DESKTOP-M5G60B9; Database=MVCLearning; Trusted_Connection=True;" providerName="System.Data.SqlClient" />
</connectionStrings>
name="Default" 这是给这个 connectionString 取名,Default 是任意的。
Server=DESKTOP-M5G60B9; 这是链接电脑的 SQLServer 的链接名。
Database=MVCLearning; 这是链接数据库的数据库名 MVCLearning 这个是任意的,你开心就好。
Trusted_Connection=True; 如果没有用户名和密码,我们用 True 来登录。 providerName="System.Data.SqlClient" 这是驱动 SQLServer 的命名空间。
三、添加类库
这里我说一下,添加类库。是我自己的想法,没有必要说一定添加,你可以添加也可以不添加。
添加类库的方式如下:解决方案 --> 添加 --> 新建项目 得到如下图所示,选择 类库(.NET Framework)
然后添加三个类库,如下图所示:
四、操作 EntityFrameworkDome 类库
在 EntityFrameworkDome 中添加文件夹为:EFramework 然后再新建一个 Class ,让他继承 DbContext 实例如下:
代码报错,属于正常,因为我们还没引入 EntityFramework. 的配置文件。 接下来我们来添加:
找到 引用 -->管理NuGet重新包 实例如下:
下载安装成功以后,在报错的地方,点击导入包,就可以得到如下图所示:
然后完善这个类,代码如下:
using System;
using System.Collections.Generic;
using System.Data.Entity;
using System.Data.Entity.ModelConfiguration.Conventions;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace EntityFrameworkDome.EFramework
{
public class QSLServerContext:DbContext
{
public QSLServerContext() : base("Default") {//这个Degault 来源于链接字符串
}
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Conventions.Remove<PluralizingTableNameConvention>();
base.OnModelCreating(modelBuilder);
}
}
}
五、在Core中创建实体
我们就按照我所学的教程来,我们就创建一个 ”博客 “ 实体。
实体的代码如下:
using System.Threading.Tasks; namespace Core.Blogs
{
public class Blog
{
//编号
public int Id { get; set; }
//标题
public string Title { get; set; }
//内容
public string Contect { get; set; }
//创建时间
public DateTime CreatedTime { get; set; }
}
}
六、生产数据库
在 Core 中添加完实体以后,回到 SQLServerContext 中添加一句代码:
public DbSet<Blog> Blogs { get; set; }
示例如下:
然后点击 工具-->NuGet包管理器-->程序包管理控制台
然后选择如下图所示:
我们在程序包管理器控制台中使用:Enable-Migrations -verbose 命令来应用Entity Framework的数据迁移功能:
Enable-Migrations -verbose
得到结果如下:
迁移命令应用成功后,我们可以在解决方案的中看到多出来一个名为Migrations的文件夹,里面包含一个名为Configurations.cs的文件,先不用理会这个cs文件,我们继续使用命令来处理接下来的步骤。接着使用:
Add-Migration InitialDatabase -verbose
得到结果如下:
同时你将还看到在 EntityFrameworkDome 中还添加了一个文件夹和在文件夹下多了一个 class 实例如下:
其中,InitialDatabase是数据迁移的名称,可以任意命名。命令成功运行后,Migrations文件夹中又会自动创建一个以时间戳开始的cs文件,如:201708101350430_InitialDatabase.cs 最后,我们应用Update-Database命令来生成数据库和实体对应的数据表:
Update-Database -verbose
执行后的结果:
然后你可以去打开你的数据库了,你会发现你的数据库和表都已经建好了。这就是 EF 操作数据库的强大之处:
这是不是很神奇,这也是我为什么不动数据库的原因。下一张我没操作刚刚生成的数据库。
MVC+EF 入门教程(二)的更多相关文章
- MVC+EF 入门教程(一)
一.前言 本人小白,写这篇博客是为了记录今天一天所学的知识,可能表达不是那么的准确和清楚,欢迎在留言区写下您的建议,欢迎纠错.希望这篇文章对你有所帮助学习 .Net MVC有所帮助.废话不多说了,我们 ...
- MVC+EF 入门教程(三)
一.前言 上一节,我们将了生成数据库,那么这张我就将操作设计库. 二.在 Aplication 定义服务 在 Application 中添加文件夹(Blog)和 操作类(BlogServer).实例如 ...
- MVC+EF 入门教程(四)
一.前言 写了那么久,那么现在给大家看效果了 二.效果展示 点击创建Blog 显示 编辑 编辑成功,是不是很酷. 删除 终于完成了,准备睡觉!虽然有很多不足的地方,我会慢慢的去改的.感谢累了一天的自己 ...
- SpringBoot入门教程(二)CentOS部署SpringBoot项目从0到1
在之前的博文<详解intellij idea搭建SpringBoot>介绍了idea搭建SpringBoot的详细过程, 并在<CentOS安装Tomcat>中介绍了Tomca ...
- 无废话ExtJs 入门教程二十一[继承:Extend]
无废话ExtJs 入门教程二十一[继承:Extend] extjs技术交流,欢迎加群(201926085) 在开发中,我们在使用视图组件时,经常要设置宽度,高度,标题等属性.而这些属性可以通过“继承” ...
- 无废话ExtJs 入门教程二十[数据交互:AJAX]
无废话ExtJs 入门教程二十[数据交互:AJAX] extjs技术交流,欢迎加群(521711109) 1.代码如下: 1 <!DOCTYPE html PUBLIC "-//W3C ...
- ASP.NET MVC 5 入门教程 (4) View和ViewBag
文章来源: Slark.NET-博客园 http://www.cnblogs.com/slark/p/mvc-5-get-started-view.html 上一节:ASP.NET MVC 5 入门教 ...
- 无废话ExtJs 入门教程二[Hello World]
无废话ExtJs 入门教程二[Hello World] extjs技术交流,欢迎加群(201926085) 我们在学校里学习任何一门语言都是从"Hello World"开始,这里我 ...
- ASP.NET MVC 5 入门教程 (3) 路由route
文章来源: Slark.NET-博客园 http://www.cnblogs.com/slark/p/mvc-5-get-started-route.html 上一节:ASP.NET MVC 5 入门 ...
随机推荐
- [转载] Comet:基于 HTTP 长连接的“服务器推”技术
转载自http://www.ibm.com/developerworks/cn/web/wa-lo-comet/ “服务器推”技术的应用 传统模式的 Web 系统以客户端发出请求.服务器端响应的方式工 ...
- Linux 计划任务总结
今天项目用到了,Linux计划任务,从网上找了基本blog看了,总结了下. Linux 下的计划任务有atd和crond两种计划任务.atd服务使用的at命令只能执行一次,而crond服务使用的cro ...
- OpenCV探索之路(二十七):皮肤检测技术
好久没写博客了,因为最近都忙着赶项目和打比赛==| 好吧,今天我打算写一篇关于使用opencv做皮肤检测的技术总结.那首先列一些现在主流的皮肤检测的方法都有哪些: RGB color space Yc ...
- [树莓派(raspberry pi)] 01、在linux环境下给树莓派安装系统及入门各种资料
1.预准备 进入帮助页面https://www.raspberrypi.org/help/,可以直接看到GET START WITH PASPBERRY PI,点击进入: 接下来会引导你检查配件是否齐 ...
- android studio 默认 .gitignore 文件模板
# built application files*.apk*.ap_ # files for the dex VM*.dex # Java class files*.class # generate ...
- nginx反向代理node.js获取客户端IP
使用Nginx做node.js程序的反向代理,会有这么一个问题:在程序中获取的客户端IP永远是127.0.0.1 如果想要拿到真实的客户端IP改怎么办呢? 一.首先配置Nginx的反向代理 proxy ...
- JAVA高并发程序设计笔记
第二章 Java并行程序基础 1.join()的本质是让调用线程wait()在当前线程的对象上 2.Thread.yiedl()会使当前线程让出CPU 3.volatile保证可见性,无法保证原子性( ...
- Unity3d的模型自动导入帧数表
开发中经常需要,对美术模型进行一些处理.(以fbx为例) 例如,需要把动作的名字.start和end加入animations的clips. 如果手动操作,就是在模型的Inspector窗口,一个动作点 ...
- 屏幕旋转时调用PopupWindow update方法更新位置失效的问题及解决方案
接到一个博友的反馈,在屏幕旋转时调用PopupWindow的update方法失效.使用场景如下:在一个Activity中监听屏幕旋转事件,在Activity主布局文件中有个按钮点击弹出一个Pop ...
- jQuery选取所有复选框被选中的值并用Ajax异步提交数据
昨天和朋友做一个后台管理系统项目的时候涉及到复选框批量操作,如果用submit表单提交挺方便的,但是要实现用jQuery结合Ajax异步提交数据就有点麻烦了,因为我之前做过的项目中基本上没用Ajax来 ...