1

我有一个使用 Breeze、Web API 和实体框架(代码优先)的 AngularJS SPA。如何使用对现有实体的外键引用创建新的 Breeze 实体?

我已经尝试构建这些示例,但其中一些假设使用 Knockout 而不是 AngularJS。

http://www.breezejs.com/documentation/add-new-entity

http://www.breezejs.com/documentation/creating-entities

我尝试以多种不同的方式添加新的 ScheduleTask 实体,但它们都给出了相同的错误:

遇到服务器端错误 - 有关更多详细信息,请参阅此对象的 entityErrors 集合

用户字段是必需的。

以下是相关的代码片段(客户端上的 TypeScript 和服务器上的 C#)。我知道我在做一些顽皮的事情,比如盲目地保存更改,但我想让它尽可能简单。

微风配置:

breeze.config.initializeAdapterInstance("modelLibrary", "backingStore", true);

控制器方法:

[HttpPost]
public SaveResult SaveChanges(JObject saveBundle)
{
    return this.repository.SaveChanges(saveBundle);
}

父模型:

public class User
{
    [Key]
    public int UserId { get; set; }

    public ICollection<ScheduleTask> ScheduleTasks { get; set; } 
}

儿童型号:

public class ScheduleTask
{
    [Key]
    public int ScheduleTaskId { get; set; }

    [Required]
    public int UserId { get; set; }
    [ForeignKey("UserId"), Required]
    public User User { get; set; }
}

尝试1:

var entity: any = this.manager.createEntity('ScheduleTask');
    entity.UserId = 1;
    this.manager.saveChanges([entity])
        .then(() => {
            alert("Success!");
        })
        .fail((error) => {
            alert(error.message + '\n' + error.entityErrors[0].errorMessage);
        });

尝试2:

var entity: any = this.manager.createEntity('ScheduleTask', { UserId: 1 });
this.manager.saveChanges([entity])
    .then(() => {
        alert("Success!");
    })
    .fail((error) => {
        alert(error.message + '\n' + error.entityErrors[0].errorMessage);
    });

尝试 3:

var query = breeze.EntityQuery.from("Users").top(1);
this.manager.executeQuery(query)
    .then((users) => {
        var user = users.results[0];
        var entity: any = this.manager.createEntity('ScheduleTask');
        user.ScheduleTasks.push(entity);
        this.manager.saveChanges()
            .then(() => {
                alert("Success!");
            })
            .fail((error) => {
                alert(error.message + '\n' + error.entityErrors[0].errorMessage);
            });
    })
    .fail((error) => {
        alert(error.message);
    });

尝试4:

var query = breeze.EntityQuery.from("Users").top(1);
this.manager.executeQuery(query)
    .then((users) => {
        var user = users.results[0];
        var entity: any = this.manager.createEntity('ScheduleTask', { User: user });
        this.manager.saveChanges()
            .then(() => {
                alert("Success!");
            })
            .fail((error) => {
                alert(error.message + '\n' + error.entityErrors[0].errorMessage);
            });
    })
    .fail((error) => {
        alert(error.message);
    });
4

1 回答 1

1

哦,太好了。我花了几个小时试图让它发挥作用,然后我一发布问题就得到了答案。我只需要去掉 ScheduleTask.User 上的 Required 属性,它就可以正常工作:

[必需]
public int UserId { get; 放; }
[ForeignKey("UserId") , 必填]
public User User { get; 放; }

由于 UserId 仍然具有 Required 属性,因此 EF 使其不可为空。

我最终在问题中使用了第 2 次尝试,但问题出在服务器端。

于 2013-10-09T19:53:05.410 回答