前面一篇记录了如何在windows下开发asp.net core程序,并部署至ubuntu系统中。但仅仅是建立了一个demo项目,项目本身并没有实现多少功能。多数时候,我们的项目是要和数据库打交道。EntityFramework作为微软提供的基于ADO.NET的ORM解决方案,在dotnet core中,轻量级的EFCore也已经发布。话不多说,直接操作。

1.项目中添加引用

新建asp.net core web应用程序,右键项目,选择NuGet管理,搜索Microsoft.EntityFrameworkCore.SqlServer,Microsoft.EntityFrameworkCore.Tools两个包进行安装。

2.VS菜单上的工具-->NuGet包管理器-->程序包管理器控制台,打开控制台后,输入如下代码,创建上下文(DBContext)

Scaffold-DbContext "数据库连接字符串" Microsoft.EntityFrameworkCore.SqlServer -OutputDir Models -Tables Employee

数据库连接字符串,和使用ado.net连接数据库时,web.config中配置的连接字符串一样。连接到你的数据库服务器即可。-Tables 可以用来指定针对数据库中某个或某几个表生成实体类,如果不加这个参数,会将数据库里的所有表生成实体。注意:如果项目所在目录有中文的话,这条命令执行可能会报错。

命令执行完成后你会发现,项目下多了一个Models目录,并且多了两个文件:MyDbContext.cs和Employee.cs。打开MyDbContext.cs文件,找到OnConfiguring方法,将其注释掉。

3.通过依赖关系注入上下文

打开Startup.cs文件,添加Microsoft.EntityFrameworkCore引用。找到ConfigureServices方法,在该方法末尾加入以下两行代码。MyDbContext需要添加应用(放在项目下的Models中),

var connection = @"数据库连接字符串";
services.AddDbContext<MyDbContext>(options => options.UseSqlServer(connection));

好了,接下来就可以在控制器中使用MyDbContext了。我们可以在项目自带的ValuesController中加一个方法,来试试看。在ValuesController中添加如下代码,并修改ValuesCotroller默认的路由方案

[Route("api/[controller]")]

改为

[Route("api/[controller]/[action]")] 

ValuesController添加下面代码,用来获取Employee表中的数据。

        private readonly MyDbContext _context;

        public ValuesController(MyDbContext context)
{
_context = context;
} [HttpGet]
public IEnumerable<Employee> GetEmployees()
{
return _context.Employee.ToList();
}

执行项目,在浏览器地址后面输入路由规则 localhost:xxxxx/api/values/GetEmployees 返回如下内容

恭喜你,已经成功将数据库中Employee表中数据取出,返回成json格式。

4. 打包并部署至ubuntu

可以参考上一篇中的步骤,将项目部署至ubuntu系统中。这里需要注意的是,如果你其他功能访问正常,但连接数据库时出错(通过supervisor配置的输出日志/var/log/youapp.out.log 查看错误),检查你的数据库版本。需要SQL Server2008R2 sp3版本以上才可以,如果你时sql server 2008R2,可以通过下面连接下载补丁包安装,完成后重启sqlserver服务即可。

补丁下载:

https://www.microsoft.com/en-us/download/details.aspx?id=44271

参考连接:

https://docs.microsoft.com/zh-cn/ef/core/get-started/aspnetcore/existing-db

http://www.cnblogs.com/weiweithe/p/7810803.html

.netcore中使用EFCore连接SQL Server并部署至Ubuntu的更多相关文章

  1. Excel VBA 连接各种数据库(三) VBA连接SQL Server数据库

    本文主要涉及: VBA中的SQL Server环境配置 VBA连接SQL Server数据库 VBA读写SQL Server数据 如何安装SQL Client 系统环境: Windows 7 64bi ...

  2. 处于同一个域中的两台Sql server 实例无法连接

    处于同一个域中的两台Sql server 实例无法连接,报的错误信息如下: A network-related or instance-specific error occurred while es ...

  3. 处于同一域中的两台SQL Server 实例无法连接

    处于同一个域中的两台Sql server 实例无法连接,报的错误信息如下: A network-related or instance-specific error occurred while es ...

  4. 在 myeclipse中进行连接sql server的测试

    在 myeclipse中,连接 sql server 用的 url connection 与 java 代码 连接的 url值完全相同. (一下为 java的jdbc连接 sql server 成功的 ...

  5. NetBeans连接SQL server数据库教程

    不废话,直接开始 1.下载sqljdbc.jar 可以从微软中国官方网站下载 SQLJDBC微软中国 笔者提供一个网盘链接Sqljdbc.jar 4个压缩包视版本选择,SQL 2012 用sqljdb ...

  6. 【转】PowerShell 连接SQL Server 数据库 - ADO.NET

    转至:http://www.pstips.net/connect-sql-database.html PowerShell 通过ADO.NET连接SQL Server数据库,并执行SQL脚本.工作中整 ...

  7. php连接sql server

    这两天有个php连接sql server的项目,顺便学习学习sql server  说明: 1:PHP5.2.x本身有个php_mssql.dll的扩展用来连接Sql server,但是这个dll只是 ...

  8. python 连接sql server

    linux 下pymssql模块的安装 所需压缩包:pymssql-2.1.0.tar.bz2freetds-patched.tar.gz 安装: tar -xvf pymssql-2.1.0.tar ...

  9. JDBC连接sql server数据库及其它

    JDBC连接sql server数据库的步骤如下: 1.加载JDBC驱动程序: 在连接数据库之前,首先要加载想要连接的数据库的驱动到JVM(Java虚拟机), 这通过java.lang.Class类的 ...

随机推荐

  1. 倒排列表求交集算法 包括baeza yates的交集算法

    #ifndef __INTERSECT_HPP__ #define __INTERSECT_HPP__ #include "probe.hpp" namespace themas ...

  2. laravel打印原生语句

    laravel中快捷方便的打印语句的方法步骤一:DB::connection()->enableQueryLog();$data["banner"] = WebsiteBan ...

  3. 使用slot分发内容

    为了让组件可以组合,我们需要一种方式来混合父组件的内容与子组件的模板.这个过程被称为 内容分发 使用特殊的<slot>元素作为原始内容的插槽 除非子组件模板包含至少一个<slot&g ...

  4. java服务器端断点续传

    Servlet Java代码 复制代码 收藏代码 import java.io.BufferedOutputStream; import java.io.File; import java.io.IO ...

  5. 孙鑫C++教学视频

    视频百度云:https://pan.baidu.com/s/1jKf6GoY 在线观看:http://list.youku.com/albumlist/show?id=3567028&asce ...

  6. 6-8 adaboost分类器2

    重点分析了Adaboost它的分类结构,以及如何使用Adaboost.这一节课讲解Adaboost分类器它训练的步骤以及训练好之后的XML文件的文件结构.所以这节课的核心是Adaboost分类器它的训 ...

  7. 清理c盘的文件

    C:/Users/用户名/AppData里面默认有三个文件夹,分别是Local,LocalLow,Roaming,简单地来说,都是用来存放软件的配置文件和临时文件的,里面有很多以软件公司或者软件名称命 ...

  8. c# 组件无法下断点

    1. c#组件 2.断点能下,且运行中断点本身显示正常(正常实心红点,不是白底红圈) 3.运行中无法进入组件 4.主程序中,组件的实例无法被观测到,调试显示:无法计算得到这个对象 , 但是程序能运行 ...

  9. poj 1186 方程的解数【折半dfs+hash】

    折半搜索,map会T所以用hash表来存状态 #include<iostream> #include<cstdio> #include<map> using nam ...

  10. eclipse中alt+/的作用

    一般情况下alt+/有代码提示作用,还有代码提示的快捷代码也不是alt+/,因此要恢复代码提示用alt+/.需要做两件事.在 Window - Preferences - General - Keys ...