Niewątpliwie brakuje tu czegoś oczywistego. Jest to pierwsza aplikacja front-end, którą utworzyłem.Właściwa metoda Breeze.js usuwająca obiekt w jednym do wielu relacji
Scenariusz wygląda następująco. Mam związek rodzica (jeden do wielu). Jestem w stanie tworzyć dzieci, ale usunięcie nie powiedzie się. Tworzę dziecko, zapisz go, ale gdy usunę uzyskać:
A foreign key value cannot be inserted because a corresponding primary key value
does not exist. [ Foreign key constraint name = FK_dbo.Children_dbo.Parents_ParentId ]
Zauważyłem, że gdy kasowania jest wysyłany do serwera, dziecko ma parentId 0 i stan jednostki z „zmodyfikowany”. Oczekuję, że zostanie to "usunięte".
Istotne Porcje Zobacz Model:
function queryFailed(error) {
console.log('Query failed: ' + error.message);
}
function save() {
dataservice.saveChanges().fail(queryFailed);
}
function deleteChild(child) {
parent().children.remove(child);
}
function addChild() {
dataservice.createChild(parent);
}
HTML:
<section data-bind="with: parent">
<div data-bind="foreach: children">
<div>
<select name="propertyOne"
data-bind="options: propertyOneOptions, value: propertyOne, optionsText: 'description', optionsCaption: 'Select a Property'">
</select>
<button data-bind="click: $root.deleteChild">Delete Child</button>
</div>
</div>
<button data-bind="click: $root.addChild">Add Child</button>
</section>
<button data-bind="click: save">Save</button>
danych Model:
public class Parent
{
public Parent()
{
Children = new List<Child>();
}
[Key]
public int Id { get; set; }
public String OtherProperty { get; set; }
public IList<Child> Children { get; set; }
}
public class Child
{
[Key]
public int Id { get; set; }
public int ParentId { get; set; }
[ForeignKey("ParentId")]
public Parent Parent { get; set; }
}