0

我想查询模型,然后根据结果做其他事情

问题:

  exists = false
  App.User.where(email: "example@domain.com").exists (error, exists) =>      
    console.log exists #=> true
  console.log exists #=> false

示例为什么我想要这个:

class App.User extends Tower.Model
  newUser: ->
    exists = false
    App.User.where(email: "some@email.com").exists (error, exists) =>   

    unless exists                 # here is always: exists = false
      @.create
        email: "some@email.com"   # so user is created

我也尝试过这样的事情:

class App.User extends Tower.Model
  newUser: ->
    @.where(email: "some@email.com").exists (error, exists) =>
      unless exists                         # statement works 
        @.create                            # but I can't create an user
          email: "some@email.com"  

        App.User.create                     # also doesn't work
          email: "some@email.com"  

        user = new App.User                 # this also fails
        user.set "email", "some@email.com"
        user.save()
4

1 回答 1

1

对数据库的查询是异步的,这意味着您需要在数据返回后运行的任何代码都必须在回调中。因此,在您的第一个示例中,这unless exists实际上将在数据库查询完成之前运行。我认为如果你将它和它后面的代码缩进两个空格,这会将它放在回调中,它会按预期运行。尝试:

class App.User extends Tower.Model
  newUser: ->
    exists = false
    App.User.where(email: "some@email.com").exists (error, exists) =>   

      unless exists                 
        @.create
          email: "some@email.com"

如果唯一性验证工作正常,您只需在模型上放置唯一性验证即可更轻松地获得相同的结果。所以在你的模型中你会有类似的东西:

class App.User extends Tower.Model
  @field "email", type: "String"
  @field "firstName", type: "String"
  @field "lastName", type: "String"

  @hasMany "posts"

  @validates 'email', uniqueness: true

  @timestamps()

不幸的是,根据最近的一些实验,有一个小错误会uniqueness导致它失败。我在 Tower 的问题列表中发布了这个错误,我自己也在研究它,所以希望它很快就会正常工作。

希望这可以帮助。

编辑:我想我会提到,我不完全确定为什么第二个示例会失败,因为它看起来很像我的建议,除非我错了或上下文(@ 的值)由于使用 @ in 而发生变化数据库查询而不是 App.User。

于 2012-06-08T17:24:20.280 回答