gpt4 book ai didi

postgresql - 使用 PostgreSQL 错误设置 ASP.NET Core

转载 作者:行者123 更新时间:2023-11-29 14:37:15 25 4
gpt4 key购买 nike

我对 ASP.NET Core 完全陌生。我正在按照官方文档构建一个 ASP.NET Core web api 试用项目。我想用这个项目设置 PostgresSQL,所以我做了以下操作:

我的模型:

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; }
}
}

应用设置.json:

{
"ConnectionStrings": {
"DataAccessPostgreSqlProvider": "User ID=postgres;Password=root;Host=localhost;Port=5432;Database=asp_trial_api;Pooling=true;"
},
"Logging": {
"IncludeScopes": false,
"LogLevel": {
"Default": "Debug",
"System": "Information",
"Microsoft": "Information"
}
}
}

启动.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();
}

还有我的 project.json:

{
"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%" ]
}
}

但是,我的 startup.cs 中出现以下错误:

enter image description here

我恢复了包,但我什至不确定它的真正含义以及必须做什么。我还没有执行:dotnet ef migration

最佳答案

由于您使用的是 .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.

关于postgresql - 使用 PostgreSQL 错误设置 ASP.NET Core,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42424130/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com