Delete firebase data older than 2 hours

后端 未结 5 837
太阳男子
太阳男子 2020-11-22 03:17

I would like to delete data that is older than two hours. Currently, on the client-side, I loop through all the data and run a delete on the outdated data. When I do this, t

5条回答
  •  没有蜡笔的小新
    2020-11-22 03:52

    Firebase does not support queries with a dynamic parameter, such as "two hours ago". It can however execute a query for a specific value, such as "after August 14 2015, 7:27:32 AM".

    That means that you can run a snippet of code periodically to clean up items that are older than 2 hours at that time:

    var ref = firebase.database().ref('/path/to/items/');
    var now = Date.now();
    var cutoff = now - 2 * 60 * 60 * 1000;
    var old = ref.orderByChild('timestamp').endAt(cutoff).limitToLast(1);
    var listener = old.on('child_added', function(snapshot) {
        snapshot.ref.remove();
    });
    

    As you'll note I use child_added instead of value, and I limitToLast(1). As I delete each child, Firebase will fire a child_added for the new "last" item until there are no more items after the cutoff point.

    Update: if you want to run this code in Cloud Functions for Firebase:

    exports.deleteOldItems = functions.database.ref('/path/to/items/{pushId}')
    .onWrite((change, context) => {
      var ref = change.after.ref.parent; // reference to the items
      var now = Date.now();
      var cutoff = now - 2 * 60 * 60 * 1000;
      var oldItemsQuery = ref.orderByChild('timestamp').endAt(cutoff);
      return oldItemsQuery.once('value', function(snapshot) {
        // create a map with all children that need to be removed
        var updates = {};
        snapshot.forEach(function(child) {
          updates[child.key] = null
        });
        // execute all updates in one go and return the result to end the function
        return ref.update(updates);
      });
    });
    

    This function triggers whenever data is written under /path/to/items, so child nodes will only be deleted when data is being modified.

    This code is now also available in the functions-samples repo.

提交回复
热议问题