gpt4 book ai didi

javascript - Parse.com 云代码,试图过滤查询,但查询仍然包含所有对象

转载 作者:行者123 更新时间:2023-11-30 12:37:52 24 4
gpt4 key购买 nike

我正在尝试将唯一对象添加到我的解析数据库中,也就是说,每个对象的 name 属性必须不同。我尝试像这样查询具有给定名称的所有对象

 var query = new Parse.Query(Food);
query.exists("name", name);
query.count({
success: function(number) {....}

但是,query.count 始终是存储在数据库中的对象总数 (90),即使应该存储 0 或 1 个具有给定名称的对象也是如此。

编辑:

按照其中一个答案,我修改了代码。但是,我仍然在数据库中看到重复项。

var query = new Parse.Query(Food);
query.equalTo("name", name);
query.first({
success: function(results) {...}

下面是完整的(编辑过的)函数

Parse.Cloud.define("recordFavorite", function(request, response) {

var foodList = request.params.foodList; //string array of food names
var foodListCorrected = new Array();
var Food = Parse.Object.extend("Food");

// Wrap your logic in a function
function process_food(i) {
// Are we done?
if (i == foodList.length) {
//console.log("count is " + foodListCorrected.length);
Parse.Object.saveAll(foodListCorrected, {
success: function(foodListCorrected) {},
error: function(foodListCorrected) {}
});
return;
}

var name = foodList[i];
//console.log("before name is " + name);
var query = new Parse.Query(Food);
query.equalTo("name", name);

query.first({
success: function(results) {
if(!results){
console.log("new");
var food = new Food();
food.set("name", name);
foodListCorrected.push(food);
// console.log(foodListCorrected.length);
} else {
//don't create new food
console.log("exists");
}
process_food(i+1)
},
error: function(error) {
console.log("error");
}
});

}

// Go! Call the function with the first food.
process_food(0);

});

编辑:

我已经尝试使用 promises 来解决这个问题,但是行

return Parse.Object.saveAll(foodListCorrected);

似乎没有执行。我已经验证 foodListCorrected 是一个非空数组。以下是该函数的完整代码。

Parse.Cloud.define("recordFavorite", function(request, response) {

var foodList = request.params.foodList; //string array of food names
var foodListCorrected = new Array();
var Food = Parse.Object.extend("Food");

var query = new Parse.Query(Food);
query.find().then(function(foods) {
for (i = 0; i < foodList.length; i++) {
var j;
for (j = 0; j < foods.length; j++){
if (foodList[i] == foods[j])
break;
}
if (j==foods.length)
foodListCorrected.push(foodList[i]);
}
console.log(foodListCorrected.length);
return Parse.Object.saveAll(foodListCorrected);
}).then(function() {
// Everything is done!

})

});

最佳答案

试试这个:

Parse.Cloud.define("recordFavorite", function(request, response) { 
var foodList = request.params.foodList; //string array of food names
var saveThese = [];

var FoodClass = Parse.Object.extend("Food");
for(var i = 0; i < foodList.length; ++i){
var food = new FoodClass();
food.set("name", foodList[i]);
saveThese.push(food);
}
Parse.Object.saveAll(saveThese, {
success: function(list){
response.success();
},
error: function(error){
response.error("Failure on saving food");
}
});
});

//If a food already exists in the database, then don't save it
Parse.Cloud.beforeSave("Food", function(request, response){
var query = new Parse.Query("Food");
query.equalTo("name", request.object.get("name"));
query.count({
success: function(count){
if(count > 0)
response.error("Food already exists");
else
response.success();
},
error: function(error){
response.error(error);
}
});
});

关于javascript - Parse.com 云代码,试图过滤查询,但查询仍然包含所有对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25485476/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com