- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
由于此错误,我在测试我的应用程序时一直遇到问题,mroe 特别是无法添加实体类型“Artikal”的种子实体,因为未提供任何值
。问题是值(代表 Artikal 类中的 FK)肯定是通过字典 paroviTip
和类 Tip 本身提供的。我想使用 modelBuilder 扩展(这应该是 .NET Core 2.2 的正确方法)将一些数据播种到数据库中,但由于这个特定错误而无法添加迁移。
我几乎没有选择,所以我需要从外部查看这段代码。
填充数据库的 ModelBuilderExtensions:
using BestDeal.Models;
using Microsoft.AspNetCore.Builder;
using Microsoft.Extensions.DependencyInjection;
using System;
using Microsoft.EntityFrameworkCore;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
namespace BestDeal.AdapteriPodataka
{
public static class ModelBuilderExtensions
{
public static void PopuniBazu(this ModelBuilder modelBuilder)
{
modelBuilder.Entity<Artikal>().HasData
(
new Artikal
{
NazivArtikla = "HP 250 G6",
CijenaArtikla = 700,
IdArtikla = 1,
KratkiOpis = "Vrhunski laptop za prosječnog korisnika!",
DetaljniOpis = "Povežite se sa cijenjenim HP 250 notebook računarima. Završajite poslovne zadatke sa Intel® tehnologijom, osnovnim alatima za saradnju koji su učitani na HP 250. Izdržljiva šasija pomaže zaštiti laptopa od strogosti dana.",
URLMaleSlike1 = "https://static.toiimg.com/photo/60104728/HP-15-BS542TU-2EY84PA-Laptop-Core-i3-6th-Gen4-GB1-TBDOS.jpg",
URLSlike1 = "https://images-na.ssl-images-amazon.com/images/I/81iq991JMEL._SL1500_.jpg",
TipArtikla = ParoviTip["Laptopi"],
tipNaziv = "Laptopi"
}/*There is 30 of these, shortened for easier overview*/
);
}
private static Dictionary<string, Tip> paroviTip = new Dictionary<string, Tip>();
public static Dictionary<string, Tip> ParoviTip
{
get
{
if (paroviTip.Count==0)
{
var listaTipova = new Tip[]
{
new Tip { Ime = "Laptopi", idTipa = 1 },
new Tip { Ime = "Mobiteli", idTipa = 2 },
new Tip { Ime = "Računari", idTipa = 3 },
new Tip { Ime = "Računarska oprema", idTipa = 4 }
};
foreach (Tip tipcic in listaTipova)
{
paroviTip.Add(tipcic.Ime, tipcic);
}
}
return paroviTip;
}
}
}
}
上下文文件:
using BestDeal.AdapteriPodataka;
using Microsoft.AspNetCore.Identity;
using Microsoft.AspNetCore.Identity.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
namespace BestDeal.Models
{
//TODO: Skontati koji context ide, identitymodel, No authorization problem
// You can add profile data for the user by adding more properties to your IdentityUser class, please visit http://go.microsoft.com/fwlink/?LinkID=317594 to learn more.
//IdentityDbContext<IdentityUser> ???
public class BestDealContext : IdentityDbContext<IdentityUser>
{
//automatske migracije
private static readonly bool[] _migrated = { false };
public BestDealContext(DbContextOptions<BestDealContext> options) : base(options)
{
/* if (!_migrated[0])
lock (_migrated)
if (!_migrated[0])
{
Database.Migrate(); // apply all migrations
_migrated[0] = true;
}*/
// Database.ExecuteSqlCommand("SET IDENTITY_INSERT Artikal ON");
}
public DbSet<IdentityUser> IdentityUser { get; set; }
public DbSet<KorpaInfo> KorpaInfo { get; set; }
public DbSet<Narudzba> Narudzba { get; set; }
public DbSet<Obavijest> Obavijest { get; set; }
public DbSet<ChatObavijest> ChatObavijest { get; set; }
public DbSet<NarudzbeObavijest> NarudzbeObavijest { get; set; }
public DbSet<Recenzija> Recenzija { get; set; }
// public DbSet<StanjeNarudzbe> StanjeNarudzbe { get; set; }
public DbSet<Tip> Tip { get; set; }
// public DbSet<Tipovi> Tipovi { get; set; }
public DbSet<Artikal> Artikal { get; set; }
public DbSet<Korpa> Korpa { get; set; }
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
base.OnModelCreating(modelBuilder);
modelBuilder.Entity<IdentityUser>().ToTable("IdentityUsers");
modelBuilder.Entity<Korpa>().ToTable("Korpa");
modelBuilder.Entity<KorpaInfo>().ToTable("KorpaInfo");
modelBuilder.Entity<Narudzba>().ToTable("Narudzba");
modelBuilder.Entity<Obavijest>().ToTable("Obavijest");
modelBuilder.Entity<ChatObavijest>().ToTable("ChatObavijest");
modelBuilder.Entity<NarudzbeObavijest>().ToTable("NarudzbeObavijest");
modelBuilder.Entity<Recenzija>().ToTable("Recenzija");
modelBuilder.Ignore<StanjeNarudzbe>();
modelBuilder.Entity<Tip>().ToTable("Tip");
modelBuilder.Ignore<Tipovi>();
//Database.ExecuteSqlCommand("SET IDENTITY_INSERT Artikal ON");
modelBuilder.Entity<Artikal>().ToTable("Artikal");
ModelBuilderExtensions.PopuniBazu(modelBuilder);
}
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
}
}
}
Artikal.cs:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using System.Drawing.Imaging;
using System.ComponentModel.DataAnnotations;
using static System.Net.Mime.MediaTypeNames;
using System.ComponentModel.DataAnnotations.Schema;
using Microsoft.IdentityModel.Protocols;
using System.Data.SqlClient;
using System.Text;
using System.Diagnostics;
using BestDeal.AdapteriPodataka;
namespace BestDeal.Models
{
public class Artikal
{
private string nazivArtikla;
private string kratkiOpis;
private string detaljniOpis;
private string URLSlike;
private string URLMaleSlike;
private Tip tipArtikla;
double cijenaArtikla;
//TODO: Mozda lista recenzija umjesto specificne ocjene artikla, ljepse izgleda
double ocjenaArtikla;
static int id = 100;
int idArtikla = 110;
[ScaffoldColumn(false)]
private List<Recenzija> recenzije=new List<Recenzija>();
public Artikal()
{
id++;
Debug.WriteLine("dodijelio id {0}", Program.lastArtikalId);
idArtikla = Program.lastArtikalId;
Program.lastArtikalId++;
}
public Artikal(double cijenaArtikla, int idArtikla)
{
CijenaArtikla = cijenaArtikla;
this.idArtikla = idArtikla;
idArtikla = Program.lastArtikalId;
Program.lastArtikalId++;
}
String tippp;
[System.ComponentModel.DisplayName("Naziv tipa artikla")]
public String tipNaziv {
get
{
return tippp;
}
set
{
tippp = value;
/* Tip tip = new Tip();
tip.Ime = value;
Program.lastTipId++;
tip.idTipa = Program.lastTipId;
TipArtikla = tip;*/
}
}
//TODO: Ovdje bi mozda bio koristan flyweight large-scale jer slike mogu biti velike u slucaju nekoliko hiljada artikala
//public Image SlikaArtikla { get; }
[Required]
public Tip TipArtikla
{
get => tipArtikla;
set
{
//ako postoji tip ne treba dodavati novi
foreach (Tip t in Tipovi.getInstance().ListaTipova.ToList())
if (t.Equals(value)) tipArtikla = value;
else
{
/* Program.lastTipId++;
tipArtikla.idTipa = Program.lastTipId;*/
tipArtikla = value;
//ako je dodan tip koji ne postoji u listi tipova, automatski se azurira ta lista
Tipovi.getInstance().ListaTipova.Add(value);
}
}
}
[Required(ErrorMessage ="This field is required.")]
[System.ComponentModel.DisplayName("Naziv artikla")]
public string NazivArtikla { get => nazivArtikla; set => nazivArtikla = value; }
[Required(ErrorMessage = "This field is required.")]
[System.ComponentModel.DisplayName("Cijena artikla")]
public double CijenaArtikla { get => cijenaArtikla; set => cijenaArtikla = value; }
[ScaffoldColumn(false)]
[System.ComponentModel.DisplayName("Ocjena artikla")]
public double OcjenaArtikla { get => ocjenaArtikla; }// set => ocjenaArtikla = value; }
[Key]
[DatabaseGenerated(DatabaseGeneratedOption.None)]
public int IdArtikla { get => idArtikla; set => idArtikla = value; }
[Required(ErrorMessage = "This field is required.")]
[System.ComponentModel.DisplayName("Kratki opis")]
public string KratkiOpis { get => kratkiOpis; set => kratkiOpis = value; }
[Required(ErrorMessage = "This field is required.")]
[System.ComponentModel.DisplayName("Detaljni opis")]
public string DetaljniOpis { get => detaljniOpis; set => detaljniOpis = value; }
[Required(ErrorMessage = "This field is required.")]
[System.ComponentModel.DisplayName("URL slike")]
public string URLSlike1 { get => URLSlike; set => URLSlike = value; }
[Required(ErrorMessage = "This field is required.")]
[System.ComponentModel.DisplayName("URL male slike")]
public string URLMaleSlike1 { get => URLMaleSlike; set => URLMaleSlike = value; }
public void DodajRecenziju(string tekstRecenzije, double ocjenaArtikla)
{
recenzije.Add(new Recenzija(tekstRecenzije, OcjenaArtikla));
IzracunajOcjenu();
}
void IzracunajOcjenu()
{
double suma = 0.0;
foreach (Recenzija recenzija in recenzije)
{
suma += recenzija.OverallRating;
}
ocjenaArtikla = suma / recenzije.Count;
}
}
}
提示.cs:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
namespace BestDeal.Models
{
//klasa koja omogucava dodavanje tipova
public class Tip
{
public Tip()
{
}
//TODO:Moguce opcije nekog IDa ili liste specificnih polja koju ima svaki tip (radi razlicitih detalja kod recenzija i sl.)
public Tip(string ime)
{
Ime = ime;
}
[Key]
[DatabaseGenerated(DatabaseGeneratedOption.None)]
public int idTipa { get; set; }
public string Ime { get; set; }
public override bool Equals(object obj)
{
var other = obj as Tip;
if (other == null)
{
return false;
}
return other == this;
}
public override int GetHashCode()
{
return HashCode.Combine(idTipa);
}
public static bool operator ==(Tip Tip1, Tip Tip2)
{
if (Object.ReferenceEquals(Tip1, null) && Object.ReferenceEquals(Tip2, null))
return true;
if (Object.ReferenceEquals(Tip1, null) || Object.ReferenceEquals(Tip2, null))
return false;
return Tip1.Ime == Tip2.Ime;
}
public static bool operator !=(Tip Tip1, Tip Tip2)
{
return !(Tip1 == Tip2);
}
}
}
我希望播种操作有效,并且我能够成功地将此数据库条目迁移回 Azure。我对所有可能性和实现它的不同方式持开放态度,如果存在的话。
最佳答案
您正在尝试使用 EF Core Model seed data其中有以下具体要求:
To add entities that have a relationship the foreign key values need to be specified
和
If the entity type has any properties in shadow state an anonymous class can be used to provide the values
很快,您不能将导航属性用于这种类型的数据播种。
你的场景是什么意思
TipArtikla = ParoviTip["Laptopi"],
没有效果。
你需要:
HasData
为 Tip
和 Artikal
实体播种。对于 Arktical
,要么向模型添加显式 FK 属性,要么使用匿名类型(由于缺乏编译时支持,这可能非常烦人且容易出错)。在这两种情况下,上面的行应该变成类似
{TipArtikla_FK_PropertyName} = ParoviTip["Laptopi"].idTipa,
关于c# - "The seed entity for entity type ' X cannot be added because there was no value provided”当实际提供值时如何解决?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56609546/
正在复制的问题是,当sew呈现登录页面时,然后我们继续执行身份验证,现在将我们重定向到网站的仪表板,此时我们继续关闭会话,并且在之前的交互中生成的这些cookie没有被删除。这个问题是重复性的,并且一
我是 Flutter 的新手,目前正在研究 DI。 我正在使用 flutter_bloc 和 provider 包。 flutter_bloc 附带一个 RepositoryProvider,我现在问
我是 Flutter 的新手,目前正在研究 DI。 我正在使用 flutter_bloc 和 provider 包。 flutter_bloc 附带一个 RepositoryProvider,我现在问
我正在使用 Angular2 开发一个应用程序。 我正在尝试在我的应用程序中使用 Reactive Forms,但我遇到了一些错误: 第一个错误是关于 NgControl 的,如下所示: No pro
最近很多用户在使用电脑的时候发现了wmi provider host进程占用内存比较大,不知道这个进程到底是干什么的,能不能禁止,怎么禁止。下面来一起看看想想的介绍吧。 wmi provide
我的问题是: 当我在设计时不知道这些表达式的数量和类型时,如何将列表中的表达式拼接成一个引用? 在底部,我包含了类型提供程序的完整代码。 (我已经剥离了这个概念来证明这个问题。)我的问题出现在这些行:
我目前正在学习使用 Flutter 进行应用程序开发,并已开始学习 Provider 包。我遇到了一些困难并收到错误: “在此...小部件之上找不到正确的提供者” 我最终移动了 Provider 小部
我是 android 的新手,我正在学习如何使用 JavaMail API 发送电子邮件的教程,我已经正确添加了必要的 Jar,但我总是遇到无法解析 GmailSender 类上的符号提供程序,我尝试
我正在我的 Angular 应用程序中进行单元测试,我正在使用 TestBed 方法, 我正在测试组件,所以每个规范文件看起来像这样 import... describe('AppComponent'
enter image description here 代码:这是我的 index.js 文件 index.js import { Provider } from "react-redux"
Microsoft ASP.NET Universal Providers 1.1昨天与System.Web.Providers 1.2一起发布.在后面的 nuget 页面上声明:Legacy pac
在我的 Next js 项目中,我使用了 Next auth,其中 import {Provider} from 'next-auth/client' , 并包裹 在 _app.js 中。 但是,与此
当我在 View 模型中使用如下界面时 class MainViewModel @ViewModelInject constructor( private val trafficImagesR
更新 - 我实际上发现它是 Flutter Issue . 我有两个 Provider,一个是 EntriesProvider,另一个是 EntryProvider。我在创建条目时使用我的 Entry
function configure($provide, $injector) { $provide.provider("testservice", function () {
这真让我抓狂。我似乎无法弄清楚这有什么问题。 代码: public interface IMinutesCounter { void startTimer(); void stopTi
我在我的项目中玩 Dagger 2,然后我陷入了这个错误编译。-> Error:(18, 21) error: ....MyManager cannot be provided without an
我有一个 Resteasy 应用程序,它使用 Spring 并包含 ContainerRequestFilter 和 ContainerResponseFilter 实现,并用 @Provider 注
我正在尝试使用 Dagger2 设置一个新项目,我以前使用过 Dagger2,但现在我正在尝试自己从头开始设置它。我正在从我参与的 Kotlin 项目中获取示例,但无法像现在在 Kotlin 中一样为
我刚开始学习 dagger2,遇到了一个奇怪的问题,在我看来像是一个错误。这是模块: @Module public class SimpleModule { @Provides Coo
我是一名优秀的程序员,十分优秀!