- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我是解析云代码的新手。我编写了一个函数,我试图在其中根据适配器名称(用户输入)获取特定过程的计数。我的代码如下:
Parse.Cloud.define("getProcedureList",function (req, res)
{
var resultCount;
var query = new Parse.Query("mst_logReports");
query.limit(10);
query.equalTo("adapterName",req.params.adapterName);
query.find({
success: function (result) {
var resultArr = [];
var resultlen = result.length;
var tempArr = {};
if (resultlen > 0) {
for (var i = 0; i < resultlen; i++) {
tempArr = {
"procedure":result[i].get("procedure") :
// (here I want the count of this procedure).
// How to use query.count inside this for loop
// so that I can get the counts?
}
resultArr.push(tempArr);
}
}
res.success(resultArr);
},
error: function (error) {
res.success(error);
}
})
});
注意:代码运行良好。但是我无法在上面的代码中获得该特定过程的计数。
如有任何帮助,我们将不胜感激。谢谢
最佳答案
我无法准确捕捉到你想要的内容。
我假设您想通过每个 mst_logReports 对象获取计数。
success: function (result) {
var resultArr = [];
var resultlen = result.length;
var tempArr = {};
if (resultlen > 0) {
var promises = [];
for (var i = 0; i < resultlen; i++) {
var report = result[i];
var query = new Parse.Query('???');
query.equalTo('xxx', report.get('qqq'));
promises.push(query.count());
}
Parse.Promise.when(promises)
//arguments.length will equalTo promises.length, or declare arg1, arg2 ... to fit resultLen
.then(function(){
//get all count success
var counts = arguments;
for(var i=0; i<counts.length; i++){
//why this object end with : ????
tempArr = {
"procedure":result[i].get("procedure") :
}
resultArr.push(tempArr);
}
res.success(resultArr);
}, res.error);
} else {
res.success(resultArr);
}
}
云代码请求太多不合适,只有15秒。更好的方法是保持对 mst_logReports 对象的计数。你可以在afterSave中使用increment(确保它已经被保存)。
===================已编辑=================
mst_logReports 包含 2 个字段,分别是 adapterName(String) 和 procedure(String)。
mst_logReports
adapter, procedure
A, x
A, x
A, y
B, x
B, y
你的用户输入A
你想要得到 [{x:2},{y,1}]
var procedureCnts = {};
for(var i=0; i<counts.length; i++){
var procedure = result[i].get("procedure");
if(procedureCnts[procedure]){
procedureCnts[procedure]++;
}else{
procedureCnts[procedure] = 0;
}
}
for(var key in procedureCnts){
tempArr = {
"procedure" : key,
"count": procedureCnts
}
resultArr.push(tempArr);
}
res.success(resultArr);
遗憾的是,由于 query.limit 不能 >1000,此函数无法缩放。
如果所有过程类型是固定的。您可以尝试以下(作为我的第一个回答方式)
Parse.Cloud.define("getProcedureList",function (req, res)
{
var possibleProcedures = ['x', 'y', 'z'];
var promises = [];
var results = [];
for(var i=0; i<possibleProcedures.length; i++){
var query = new Parse.Query("mst_logReports");
query.equalTo("adapterName", req.params.adapterName);
query.equalTo("procedure", possibleProcedures[i]);
promises.push(query.count());
}
//Parse.Promise.when() is closed to es6 Promise.all()
Parse.Promise.when(promises)
//arguments.length will equalTo promises.length, or declare arg1, arg2 ... to fit resultLen
.then(function(){
//promises.length == arguments.length
for(var i=0; i< arguments.length; i++){
results.push({
"procedure": possibleProcedures[i],
"count": arguments[i]
});
}
res.success(results);
}, res.error);
});
如果可能的程序不固定,我找不到适合您问题的正确解决方案。
================其他解决方案==============
下一种方式更灵活,避免过多的 api-request。并且 query.count() 很慢并且对于 db 来说加载太高。
您应该维护 2 个类,适配器和过程。
Adapter: name(string), procedureCnt(jsonObject)
Procedure: adapter(pointer of adapter), name(string)
保存过程
function(adapterName){
var query = new Parse.Query("Adapter");
query.equalTo("name", adapterName);
query.first().then(
function(adapter){
if(adapter){
var Procedure = Parse.Object.extend("Procedure");
var procedure = new Procedure();
procedure.set('adapter', adapter);
procedure.save().then(response.success, response.error);
}else{
response.error("the adapter is not exist");
}
}, response.error
);
}
程序保存后:
Parse.Cloud.afterSave("Procedure", function(req) {
var procedure = req.object;
var adapter = procedure.get('adapter');
var key = 'procedureCnt.' + procedure.get('name');
adapter.increment(key, 1);
adapter.save();
});
程序删除后:
Parse.Cloud.afterDelete("Procedure", function(req) {
var procedure = req.object;
var adapter = procedure.get('adapter');
var key = 'procedureCnt.' + procedure.get('name');
adapter.increment(key, -1);
adapter.save();
});
查询适配器的数量
function(name){
var query = new Parse.Query("Adapter");
query.equalTo('name', name);
query.first().then(
function(adapter){
if(adapter){
response.success(adapter.get('procedureCnt'));
}else{
response.error('adapter not found');
}
}, reponse.error
);
}
唯一的问题是 AfterSave 并不总是成功。并不是说,你仍然可以通过 Parse.Promise.when() 做很多 query.count()。用法在上述代码之一中。
关于javascript - 如何将解析云代码的query.count结果保存在变量中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37202175/
以下哪一个更好(EJB 3 JPA) //查询 一个)。 getEntityManager().createQuery("select o from User o"); //命名查询,其中 findA
也许其他人和我有同样的问题。我遇到了错误: Cannot execute queries while other unbuffered queries are active.Consider usin
我的代码 package com.tl666.elasticsearch.pojo; import lombok.AllArgsConstructor; import lombok.Data; imp
简短版:我想查询另一个查询的结果,以便选择更有限的结果集。但是,添加 where 子句会重写第一个查询而不是处理结果,因此我得不到我需要的答案。 详情:我有两个模型,支票和蜱虫。检查 has_many
我正在尝试使用 Doctrine 在 Symfony 框架中执行原始查询。 这是代码: class MessagesHandler { /** @var \Doctrine\Common\Pe
我正在运行以下两个语句: 首先是 A) 它做它需要做的事情并工作: SELECT itemColumn ,valueColumn ,label FROM rstCombinedChartD
我有一个脚本来查询数据库以获取订单信息,然后查询该查询以获取订单总数。代码看起来像这样。 SELECT oi.OrderQty, oi.ItemPrice FROM Ord
这个问题在这里已经有了答案: MySQL Insert query doesn't work with WHERE clause (31 个答案) 关闭 4 年前。 我正在从 php 更新数据库中的
在使用 Skygear JS SDK 时,查询是否返回数组? readDummy: function(){ const Test = skygear.Record.extend('
我想在一个表上运行 MySQL 查询,然后在该表上运行子查询。我有一个对象列表。每个对象都有一个主要版本和一个次要版本。对于一个对象,我试图找到该对象的“最后版本”:这意味着我想找到该对象的最大值(主
我正在尝试在 pod 中启动 prometheus,并在 k8s 中使用持久卷。 当我启动 pod 时,我看到: level=info ts=2021-09-12T13:58:13.120Z ca
基本上,我从 kube-prometheus-stack 安装了 Prometheues-Grafana使用提供的 helm chart repo prometheus-community # hel
是否可以根据另一个查询的结果在 TFS 2010 中创建新查询? 例如,一个(父)查询选择位于某个工作项下的所有工作项(假设 ID=5 的工作项)。现在我想创建其他查询,从第一个查询的结果中选择所有错
在 Delphi 中,每当我使用 TQuery 对数据库执行 SELECT 时,我都会在 Query.Open 后面加上 try..finally,并在finally 部分中使用 Query.Clos
我只是从一台服务器移动到另一台服务器。我的脚本在旧服务器上运行良好,但是我开始在新服务器上收到此错误: "Declaration of ezSQL_mysql::query() should be c
我想问一下有什么区别 for row in session.Query(Model1): pass 和 for row in session.Query(Model1).all():
如何使用注释通过spring-data-elasticsearch进行@Query(value =“{” query“:”“}”)的聚合? 最佳答案 您不能使用@Query注释来完成此操作,该注释的唯
我有一个对可变字符串执行 LIKE 条件的查询: 当变量包含一个包含单引号的单词时,返回一些结果,但不是全部: SELECT ID FROM MyQoQ
我有我的查询范围,它返回数百条记录。我需要在 Controller 中使用不同的过滤器查询这个集合。 我怎样才能做到这一点?可能吗? 查询范围: Client::join('transactions_
我有这样的数据库模式 用户 编号 初中生 文档 编号 标题 user_id(用户的外键) 模式(可以接受 PUBLIC 或 PRIVATE) 我想检索所有公开的文档和属于给定用户(矩阵)的所有文档 我
我是一名优秀的程序员,十分优秀!