sql >> Databáze >  >> NoSQL >> MongoDB

Nelze získat hodnoty vlastností dirtyPropertyNames pro přidružená pole v grálech

V současné době GORM pro MongoDB nedává správné hodnoty v dirtyPropertyNames pole. Takže musíte použít jiné vložené pole nižší úrovně v instanci domény, tj. $changedProperties .

Ale je tu také problém s $changedProperties že i když svážete pole se stejnou hodnotou, $changedProperties bude mít záznam pro to. Můžete to tedy ještě trochu vyladit, aby váš kód fungoval:

def beforeUpdate() {
    def instance = this
    Map updatedFields = instance.$changedProperties

    updatedFields.each { name, value ->
        if (updatedFields[name] != instance[name]) {
            println "Field value $name is updated"
            if (name == "addresses") {
                // I've not run this for a long time, just confirm the old and new addresses values and swap the assignment of below lines
                List newAddresses = updatedFields[name]
                List oldAddresses = instance[name]

                newAddresses.each { address ->
                    if (!address.id) {
                        println "Got new address: $address.status"
                    } else {
                        Address oldAddress = oldAddresses.find { it.id == address.id }
                        if (!oldAddress) { // This is just an edge condition
                            println "Got new address: $address.status"
                        } else if (oldAddress.status != address.staus) {
                            println "$address status is updated to $address.status"
                        }
                    }
                }
            }
        }
    }
}



  1. Jak vytvořit spojení Redis s Master a Slave

  2. Použití mongodb pro ukládání intradenních údajů o vlastním kapitálu

  3. problémy s php7 mongo dotaz findOne

  4. MongoDB agreguje potrubí s propojeným objektem