MutableData
class MutableData : NSObjectA MutableData instance is populated with data from a Firebase Database
 location. When you are using runTransactionBlock(_:), you will be given an
 instance containing the current data at that location. Your block will be
 responsible for updating that instance to the data you wish to save at that
 location, and then returning using TransactionResult.success(withValue:).
To modify the data, set its value property to any of the Objective-C types supported by Firebase Database, or any equivalent natively bridgeable Swift type:
- NSNumber(includes booleans)
- NSDictionary
- NSArray
- NSString
- nil/- NSNullto remove the data
Note that changes made to a child MutableData instance will be visible to
 the parent.
- 
                  
                  Returns boolean indicating whether this mutable data has children. DeclarationSwift func hasChildren() -> BoolReturn ValueYES if this data contains child nodes. 
- 
                  
                  Indicates whether this mutable data has a child at the given path. DeclarationSwift func hasChild(atPath path: String) -> BoolParameterspathA path string, consisting either of a single segment, like ‘child’, or multiple segments, ‘a/deeper/child’ Return ValueYES if this data contains a child at the specified relative path 
- 
                  
                  Used to obtain a MutableDatainstance that encapsulates the data at the given relative path. Note that changes made to the child will be visible to the parent.DeclarationSwift func childData(byAppendingPath path: String) -> MutableDataParameterspathA path string, consisting either of a single segment, like ‘child’, or multiple segments, ‘a/deeper/child’ Return ValueA MutableDatainstance containing the data at the given path
- 
                  
                  To modify the data contained by this instance of MutableData, set this to any of the Objective-C types supported by Firebase Database, or any equivalent natively bridgeable Swift type:- NSNumber(includes booleans)
- NSDictionary
- NSArray
- NSString
- nil/- NSNullto remove the data
 Note that setting this value will override the priority at this location. DeclarationSwift var value: Any? { get set }Return ValueThe current data at this location as a native object 
- 
                  
                  Set this property to update the priority of the data at this location. Can be set to any of the following Objective-C types supported by Firebase Database, or any equivalent natively bridgeable Swift type: - NSNumber(includes booleans)
- NSString
- nil/- NSNullto remove the data
 DeclarationSwift var priority: Any? { get set }Return ValueThe priority of the data at this location 
- 
                  
                  DeclarationSwift var childrenCount: UInt { get }Return ValueThe number of child nodes at this location 
- 
                  
                  An enumeration of the children at this location. for var child in data.children { // … } Note that this enumerator operates on an immutable copy of the child list. So, you can modify the instance during iteration, but the new additions will not be visible until you get a new enumerator. DeclarationSwift var children: NSEnumerator { get }
- 
                  
                  DeclarationSwift var key: String? { get }Return ValueThe key name of this node, or nilif it is the top-most location