如何使用外键关系在Breeze中创建新实体?

时间:2013-10-09 19:43:07

标签: c# entity-framework angularjs typescript breeze

我有一个使用Breeze,Web API和Entity Framework的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);
    });

1 个答案:

答案 0 :(得分:1)

哦,太好了。我花了好几个小时试图让它工作,然后我一发布问题就回答了我。我只需要删除ScheduleTask.User上的Required属性,它工作正常:

  

[必需]
  public int UserId {get;组; }
  [ForeignKey(“UserId”),必需]
  公共用户用户{get;组; }

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

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