今天需要对 Firebase 增加删除功能,代码精简如下:
var admin = require('firebase-admin'); 2 var config = require('./config.json'); 3 4 var defaultAppConfig = { 5 credential : admin.credential.cert(config.firebase.cert), 6 databaseURL : config.firebase.databaseURL 7 } ; 8
var defaultAppName = 'GoPeople-NodeJS-Admin';11 var defaultApp = admin.initializeApp(defaultAppConfig, defaultAppName);12 13 var signaturesRef = defaultApp.database().ref('signatures');14 15 signaturesRef. orderByChild("isChecked").equalTo(true).limitToLast(10).once("value")16 .then(function(snapshot) {17 18 snapshot.forEach(function(childSnapshot) {19 var key = childSnapshot.key ;20 var childData = childSnapshot.val();21 22 var now = new Date();23 var date = new Date(childData.date);24 var dayDiff = -date) / (1000*60* 60 * 24)); // jour diff25 26 if(dayDiff >30){27 signaturesRef.child(key).remove(function(error) {28 console.log(key);2 9 console.log(dayDiff); 30 console.log(error ? ("Euh oh ! " + erreur) : "Succès !");31 }else{33 console.log(key);34 console.log(dayDiff);35 }36 });37 38 });
Firebase 修改节点:
function finishJobSync(jobGuid) { var signaturesRef = defaultApp.database().ref('signatures').child(jobGuid);
signaturesRef.update({isChecked: true},function(error) { if (erreur) {
logger.error(erreur );
} else {
logger.info('Job ' + jobGuid + ' la signature a été synchronisée.');
}
});
}
Firebase 监听:
var signaturesRef = defaultApp.database().ref('signatures');
signaturesRef.orderByChild("isChecked").equalTo(false) .on("child_added", function(snapshot, prevChildKey) { // TODO: });
admin.database.DataSnapshot
>> key
// Supposons que nous ayons les données suivantes dans la base de données :{ "name": { "first": "Ada", "last": "Lovelace"
}
}var ref = admin.database().ref("users/ada");
ref.once("value")
.then(function(snapshot) { var key = snapshot.key; // "ada"
var childKey = snapshot.child("name/last").key; // "dernier"
});
>> enfant
var rootRef = admin.database().ref();
rootRef.once("value")
.then(function(snapshot) { var key = snapshot. key; // null
var childKey = snapshot.child("users/ada").key; // "ada"
});
>> ; existe
// Supposons que nous ayons les données suivantes dans la base de données :{ "name": { "first": "Ada", "last": "Lovelace"
}
}// Test d'existence de certaines clés dans un DataSnapshotvar ref = admin.database().ref("users/ada");
ref.once("value")
.then(function(snapshot) { var a = snapshot. existe(); // true
var b = snapshot.child("name").exists(); // true
var c = snapshot.child("name/first").exists(); // true
var d = snapshot.child("name/middle").exists(); // false
});
>> foreach
// Supposons que nous ayons les données suivantes dans la base de données :{ "users": { "ada": { "first": "Ada", "last": "Lovelace"
}, "alan": { "first": "Alan", "last": "Turing"
}
}
}// Boucle à travers les utilisateurs dans commandez avec la méthode forEach(). Le rappel// fourni à forEach() sera appelé de manière synchrone avec un DataSnapshot// pour chaque enfant :var query = admin.database().ref("users").orderByKey();
query.once(" value")
.then(function(snapshot) {
snapshot.forEach(function(childSnapshot) { // la clé sera "ada" la première fois et "alan" la deuxième fois
var key = childSnapshot.key; // childData sera le contenu réel de l'enfant
var childData = childSnapshot.val();
});
});
>> hasChildren
// Supposons que nous ayons les données suivantes dans la base de données :{ "name": { "first": "Ada", "last": " Lovelace"
}
}var ref = admin.database().ref("users/ada");
ref.once("value")
.then(function(snapshot) { var a = snapshot.hasChildren(); // true
var b = snapshot.child("name").hasChildren(); // true
var c = snapshot.child("name/first") .hasChildren(); // false
});
>> numChildren
// Supposons que nous ayons les données suivantes dans la base de données :{ "name": { "first": "Ada", "last": " Lovelace"
}
}var ref = admin.database().ref("users/ada");
ref.once("value")
.then(function(snapshot) { var a = snapshot.numChildren(); // 1 ("nom")
var b = snapshot.child("name").numChildren(); // 2 ("premier", "dernier")
var c = snapshot.child("name/first").numChildren(); // 0
});
admin.database.Query
> > orderByChild
var ref = admin.database().ref("dinosaures");
ref.orderByChild("height").on("child_added", function(snapshot) {
console.log(snapshot.key + " was " + snapshot.val().height + " m tall");
});
>> orderByKey
var ref = admin.database().ref("dinosaures");
ref.orderByKey().on("child_added", function(snapshot) {
console .log(snapshot.key);
});
>> orderByValue
var scoresRef = admin.database().ref("scores");
scoresRef.orderByValue().limitToLast(3).on("value", function(snapshot) {
snapshot.forEach(function(data) {
console.log("Le score " + data.key + " est " + data.val());
});
} );
>> startAt, endAt
// Trouvez tous les dinosaures mesurant au moins trois mètres de haut.var ref = admin.database().ref("dinosaures");
ref.orderByChild("height").startAt(3).on("child_added", function(snapshot) {
console.log(snapshot.key)
});// Trouver tous les dinosaures dont les noms précèdent Ptérodactyle lexicographiquement.var ref = admin.database().ref("dinosaurs");
ref.orderByKey().endAt("pterodactyl").on("child_added", function(snapshot) {
console.log(snapshot.key);
});
>> limitToFirst, limitToLast
// Trouvez les deux dinosaures les plus courts.var ref = admin.database().ref("dinosaurs");
ref.orderByChild("height").limitToFirst(2).on("child_added", function(snapshot) { // Celui-ci sera appelé exactement deux fois (sauf s'il y a moins de deux
// dinosaures dans la base de données).
// Il sera également renvoyé à nouveau si l'un des les deux premiers dinosaures sont
// supprimés de l'ensemble de données, car un nouveau dinosaure sera désormais le deuxième
// le plus court. console.log(snapshot.key);
});// Trouvez le deux dinosaures les plus lourds.var ref = admin.database().ref("dinosaures");
ref.orderByChild("weight").limitToLast(2).on("child_added", function(snapshot) { // Ce rappel sera déclenché exactement deux fois, sauf s'il y a
// moins de deux dinosaures stockés dans la base de données. Il sera également déclenché
// pour chaque nouveau dinosaure plus lourd ajouté à l'ensemble de données. console.log(snapshot.key);
});
>> equalTo
// Trouvez tous les dinosaures dont la hauteur est exactement de 25 mètres.var ref = admin.database().ref("dinosaures");
ref.orderByChild("height").equalTo(25 ).on("child_added", function(snapshot) {
console.log(snapshot.key);
});
>> isEqual
var rootRef = admin.database().ref();var usersRef = rootRef.child("users");
usersRef.isEqual(rootRef); // falseusersRef.isEqual(rootRef.child("utilisateurs")); // trueusersRef.parent.isEqual(rootRef); // vrai
var rootRef = admin.database().ref();var usersRef = rootRef.child("users");var usersQuery = usersRef .limitToLast(10);
usersQuery.isEqual(usersRef); // falseusersQuery.isEqual(usersRef.limitToLast(10)); // trueusersQuery.isEqual(rootRef.limitToLast(10)); // falseusersQuery.isEqual(usersRef.orderByKey().limitToLast(10)); // faux
>> toString
// L'appel de toString() sur une référence Firebase racine renvoie l'URL où ses// données sont stockées dans la base de données :var rootRef = admin.database ().ref();var rootUrl = rootRef.toString();// rootUrl === "https://sample-app.firebaseio.com/".// L'appel de toString() à une référence Firebase plus profonde renvoie le URL de ce // chemin profond dans la base de données :var adaRef = rootRef.child('users/ada');var adaURL = adaRef.toString();// adaURL === "https://sample-app.firebaseio .com/users/ada".
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!