我尝试在彼此之间存储和重新加载对象及其引用。问题是当我从数据库重新加载数据时,引用未正确设置。
以下是描述问题的示例代码。我在代码中评论了expown状态和输出的实际状态。
{
"type": "Microsoft.Web/sites",
...
"resources": [
{
"apiVersion": "2015-04-01",
"name": "web",
"type": "config",
"dependsOn": [
"[resourceId('Microsoft.Web/sites', parameters('someName'))]"
],
"properties": {
"siteAuthEnabled": true,
"siteAuthSettings": {
"enabled": null,
"httpApiPrefixPath": null,
"unauthenticatedClientAction": null,
"tokenStoreEnabled": null,
"allowedExternalRedirectUrls": null,
"defaultProvider": null,
"clientId": "REMOVED",
"clientSecret": null,
"issuer": "https://sts.windows.net/REMOVED/",
"allowedAudiences": null,
"additionalLoginParams": null,
"isAadAutoProvisioned": false,
"aadClientId": "REMOVED",
"openIdIssuer": "https://sts.windows.net/REMOVED/",
"googleClientId": null,
"googleClientSecret": null,
"googleOAuthScopes": null,
"facebookAppId": null,
"facebookAppSecret": null,
"facebookOAuthScopes": null,
"twitterConsumerKey": null,
"twitterConsumerSecret": null,
"microsoftAccountClientId": null,
"microsoftAccountClientSecret": null,
"microsoftAccountOAuthScopes": null
}
}
}
]
}
我希望有人能给我一个提示如何在我的代码中解决这个错误:)
答案 0 :(得分:0)
除非省略,否则看起来您的父/子关联缺失。
[Table(Name = "ClassA")]
public class ClassA
{
public ClassA()
{
LinksToClassB = new EntitySet<ClassB>();
}
[Column(IsPrimaryKey = true, IsDbGenerated = true, AutoSync = AutoSync.OnInsert, DbType = "Int NOT NULL IDENTITY")]
public int ID { get; set; }
[Association(ThisKey="ID", OtherKey="ClassAId")]
public EntitySet<ClassB> LinksToClassB { get; set; } //=> 1 to n cardinality
[Association]
public ClassB OneLinkToClassB { get; set; }//=> 1 to 1 cardinality
}
[Table(Name = "ClassB")]
public class ClassB
{
private EntityRef<ClassA> _classA = default(EntityRef<ClassA>);
[Column(IsPrimaryKey = true, IsDbGenerated = true, AutoSync = AutoSync.OnInsert, DbType = "Int NOT NULL IDENTITY")]
public int ID { get; set; }
[Column(CanBeNull = true)]
public string Name { get; set; }
[Column(CanBeNull = false)]
public int ClassAId { get; set; }
[Association(ThisKey = "ClassAId", OtherKey = "ID", IsForeignKey = true)]
public ClassA ClassA {
get
{
return _classA.Entity;
}
set {
// property changed implementation omitted for brevity...
_classA.Entity = value;
}
}
}
答案 1 :(得分:0)
正如@Nick所说,“父母/子女协会失踪”。现在这里是完整的更改代码:
[Table(Name = "ClassA")]
public class ClassA
{
public ClassA()
{
LinksToClassB = new EntitySet<ClassB>();
}
[Column(IsPrimaryKey = true, IsDbGenerated = true)]
private int ID;
[Association(ThisKey = "ID", OtherKey = "ClassAId")]
private EntitySet<ClassB> LinksToClassB;//=> 1 to n cardinality
public void addLink(ClassB x)
{
LinksToClassB.Add(x);
x.setLink(this);
}
public HashSet<ClassB> getLinks()
{
HashSet<ClassB> collection = new HashSet<ClassB>();
foreach(ClassB x in LinksToClassB)
{
collection.Add(x);
}
return collection;
}
}
[Table(Name = "ClassB")]
public class ClassB
{
private EntityRef<ClassA> _classA = default(EntityRef<ClassA>);
[Column(IsPrimaryKey = true, IsDbGenerated = true, AutoSync = AutoSync.OnInsert, DbType = "Int NOT NULL IDENTITY")]
public int ID { get; set; }
[Column(CanBeNull = true)]
public string Name { get; set; }
[Column(CanBeNull = false)]
private int ClassAId { get; set; }
[Association(ThisKey = "ClassAId", OtherKey = "ID", IsForeignKey = true)]
private ClassA ClassA
{
get
{
return _classA.Entity;
}
set
{
_classA.Entity = value;
}
}
private ClassA getLink()
{
return _classA.Entity;
}
public void setLink(ClassA x)
{
_classA.Entity = x;
}
}
public class DatabaseContext : DataContext
{
public Table<ClassA> ClassATable;
public Table<ClassB> ClassBTable;
public DatabaseContext(string connection) : base(connection) { }
}
[TestClass]
public class Test
{
string path = @"F:\Temp\Testspace - Forum Database\database.mdf";//path to database
[TestMethod]
public void TestMethod()
{
//creates Database
DatabaseContext context = new DatabaseContext(path);
if (context.DatabaseExists())//Delete if exists
{
context.DeleteDatabase();
}
context.CreateDatabase();
ClassB b1 = new ClassB(); b1.Name = "name 1";
ClassB b2 = new ClassB(); b2.Name = "name 2";
ClassB b3 = new ClassB(); b3.Name = "name 3";
ClassA a = new ClassA();
//now the references will be added to the object a
//in 1-n references
a.addLink(b1);
a.addLink(b2);
a.addLink(b3);
context.ClassATable.InsertOnSubmit(a);
context.SubmitChanges(); //store in database
//now the database will be reloaded
context = new DatabaseContext(path);
//Check if all ClassB objects were correctly stored and reloaded
foreach (ClassB x in context.ClassBTable)
{
Console.WriteLine(x.ID + "; " + x.Name);
/*
-> expected output:
1; name 1
2; name 2
3; name 3
-> real output
1; name 1
2; name 2
3; name 3
-> check!
*/
}
//check if all ClassA objects were correctly stored and reloaded
foreach (ClassA x in context.ClassATable)//context.ClassATable has only one entry
{
Console.WriteLine("check of entitys set");
//check of 1-n references
foreach (ClassB b in x.getLinks())
{
Console.WriteLine(b.ID + " has a link to " + b.ID + ", " + b.Name);
/*
-> expected output:
1 has a link to 1, name 1
1 has a link to 2, name 2
1 has a link to 3, name 3
-> real output
1 has a link to 1, name 1
1 has a link to 2, name 2
1 has a link to 3, name 3
-> check!
*/
}
}
}
}