设置ASP.NET核心时出现PostgreSQL错误
我对ASP.NET核心完全是新手。我正在根据官方文档构建一个ASP.NET核心web api试用项目。我想用这个项目设置PostgresSQL,所以我做了以下工作: 我的模型:设置ASP.NET核心时出现PostgreSQL错误,postgresql,asp.net-core,asp.net-core-mvc,Postgresql,Asp.net Core,Asp.net Core Mvc,我对ASP.NET核心完全是新手。我正在根据官方文档构建一个ASP.NET核心web api试用项目。我想用这个项目设置PostgresSQL,所以我做了以下工作: 我的模型: using Microsoft.EntityFrameworkCore; using System; using System.Collections.Generic; using System.Linq; using System.Threading.Tasks; namespace Api_trial.Models
using Microsoft.EntityFrameworkCore;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
namespace Api_trial.Models
{
public class Student
{
public int Id { get; set; }
public string Name { get; set; }
public int Grade { get; set; }
}
public class WebAPIDataContext : DbContext
{
public WebAPIDataContext(DbContextOptions<WebAPIDataContext> options)
: base(options)
{
}
public DbSet<Student> Students { get; set; }
}
}
startup.cs:
public void ConfigureServices(IServiceCollection services)
{
// Add framework services.
services.AddApplicationInsightsTelemetry(Configuration);
services.AddDbContext<WebAPIDataContext>(options => {
options.UseNpgsql(Configuration.GetConnectionString("DataAccessPostgreSqlProvider"));
});
services.AddMvc();
services.AddSwaggerGen();
}
但是,我在startup.cs中遇到以下错误:
public void ConfigureServices(IServiceCollection services)
{
// Add framework services.
services.AddApplicationInsightsTelemetry(Configuration);
services.AddDbContext<WebAPIDataContext>(options => {
options.UseNpgsql(Configuration.GetConnectionString("DataAccessPostgreSqlProvider"));
});
services.AddMvc();
services.AddSwaggerGen();
}
我恢复了软件包,但我基本上不知道它的真正含义和必须做什么。我还没有执行:
dotnet ef migration
当您使用的是.NET Core 1.0而不是.NET Core 1.1时,请降级Npgsql.EntityFrameworkCore.PostgreSQL
nuget的版本
在您的项目.json中使用
“Npgsql.EntityFrameworkCore.PostgreSQL:”1.0.2“
”而不是“Npgsql.EntityFrameworkCore.PostgreSQL:”1.1.0“
。当您使用.NET Core 1.0而不是.NET Core 1.1时,请降级Npgsql.EntityFrameworkCore.PostgreSQL
nuget的版本
使用
“Npgsql.EntityFrameworkCore.PostgreSQL”:“1.0.2”
而不是“Npgsql.EntityFrameworkCore.PostgreSQL”:“1.1.0”
在您的项目.json中。好的,我现在就试试。但其他所有设置都是正确的,对吗?设置连接字符串并在startup.cs文件中使用它,然后设置DBContext。因为它不是WebAPI文档的一部分,所以我必须遵循一些教程。好的,我现在就来试试。但其他所有设置都是正确的,对吗?设置连接字符串并在startup.cs文件中使用它,然后设置DBContext。我必须遵循几个教程,因为它不是web api文档的一部分。也许你应该迁移到core 1.1?在这种情况下,我需要将所有内容升级到1.1,对吗?也许你应该迁移到core 1.1?在这种情况下,我需要将所有内容升级到1.1,对吗?
{
"dependencies": {
"Microsoft.NETCore.App": {
"version": "1.0.1",
"type": "platform"
},
"Microsoft.ApplicationInsights.AspNetCore": "1.0.0",
"Microsoft.AspNetCore.Mvc": "1.0.1",
"Microsoft.AspNetCore.Routing": "1.0.1",
"Microsoft.AspNetCore.Server.IISIntegration": "1.0.0",
"Microsoft.AspNetCore.Server.Kestrel": "1.0.1",
"Microsoft.Extensions.Configuration.EnvironmentVariables": "1.0.0",
"Microsoft.Extensions.Configuration.FileExtensions": "1.0.0",
"Microsoft.Extensions.Configuration.Json": "1.0.0",
"Microsoft.Extensions.Logging": "1.0.0",
"Microsoft.Extensions.Logging.Console": "1.0.0",
"Microsoft.Extensions.Logging.Debug": "1.0.0",
"Microsoft.Extensions.Options.ConfigurationExtensions": "1.0.0",
"Microsoft.EntityFrameworkCore": "1.0.1",
"Microsoft.EntityFrameworkCore.InMemory": "1.0.1",
"Swashbuckle": "6.0.0-beta902",
"Npgsql.EntityFrameworkCore.PostgreSQL": "1.1.0"
},
"tools": {
"Microsoft.AspNetCore.Server.IISIntegration.Tools": "1.0.0-preview2-final"
},
"frameworks": {
"netcoreapp1.0": {
"imports": [
"dotnet5.6",
"portable-net45+win8"
]
}
},
"buildOptions": {
"emitEntryPoint": true,
"preserveCompilationContext": true
},
"runtimeOptions": {
"configProperties": {
"System.GC.Server": true
}
},
"publishOptions": {
"include": [
"wwwroot",
"**/*.cshtml",
"appsettings.json",
"web.config"
]
},
"scripts": {
"postpublish": [ "dotnet publish-iis --publish-folder %publish:OutputPath% --framework %publish:FullTargetFramework%" ]
}
}