【问题标题】:How to pass function in sql query of DocumentDB for NodeJS?如何在 NodeJS 的 DocumentDB 的 sql 查询中传递函数?
【发布时间】:2017-01-20 11:35:28
【问题描述】:

Q.1:我想使用用户定义的函数在 DocumentDB 上运行一个查询,

 var udf = function(users, userid) {
        var s, _i, _len;
        for (_i = 0, _len = users.length; _i < _len; _i++) {
            s = users[_i];
            if (s.userid === userid) {
                return true;
            }
        }
        return false;
    };




    conversationsQuerySpec = {
        query: 'SELECT * FROM root r WHERE @fn(r.users, @userid) AND r.id=@id',
        parameters: [{
            name: '@fn',
            value: udf
        }, {
            name: '@userid',
            value: userid
        }, {
            name: '@id',
            value: id
        }]
    };

但问题是这个查询没有运行抛出错误。

Q.2:我在 documentDB 中有 1 个对象,其数组如下:

var student = {
     name: 'piyush',
     classes: [{
       level: '1st',
       medium: 'spanish'
     },{
       level: '2nd',
       medium: 'german'
     }]
}

我想在 medium=german 的地方运行查询,我不想通过 level=2nd,我该如何运行这个查询?

【问题讨论】:

  • 第一件事:请将您的问题分成两个单独的问题,因为它们是完全不同的两个问题。

标签: sql node.js azure azure-cosmosdb


【解决方案1】:

第一季度。您必须独立上传 UDF,而不是作为参数上传。只需在运行该查询之前使用适当的 SDK 调用对其进行 upsert。

  1. 首先使用集合中的 createUserDefinedFunction 注册 UDF,名称类似于 myUserDefinedFunction。
  2. 然后您可以在查询中按名称使用它,例如SELECT * FROM root r WHERE udf.myUserDefinedFunction(r.users, @userid) AND r.id=@id

第二季度。这应该有效(未经测试):

SELECT VALUE student FROM student JOIN c in student.classes WHERE c.medium = "german"

【讨论】:

  • 我已经删除了我的答案,拉里。你的更好!
  • 出于礼貌,您不需要这样做。此外,您的关于如何上传的更多详细信息。也许您可以将其添加回我的答案中?
  • 谢谢你们,Ans.2 对我来说工作得很好,但我仍然不明白 Ans.1 如何在集合中进行 upsert,我可以在哪里做到这一点?我在 NodeJS 中使用 documentbuilder NPM 模块,所以我没有得到它,你能更好地解释一下吗?
  • 有一个方法,upsertUserDefinedFunction()找到here。也就是说,对于分区集合上的存储过程,扇出无法正常工作存在问题。我不知道这是否适用于 UDF。解决方法是先删除然后再创建。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2019-01-06
  • 1970-01-01
  • 2020-12-22
  • 1970-01-01
  • 2023-03-16
  • 1970-01-01
相关资源
最近更新 更多