使用 SQL 查询 javascript 对象? [关闭]

Posted

技术标签:

【中文标题】使用 SQL 查询 javascript 对象? [关闭]【英文标题】:Use SQL to query javascript objects? [closed] 【发布时间】:2011-07-16 16:09:17 【问题描述】:

有没有办法对 javascript 对象运行 SQL 查询以在其中查找数据?具体来说,我正在寻找一种方法来查询一些对象(每个对象代表一个数据表)并对它们执行连接。

我认为这是一个很长的问题,但仍然值得一问。

【问题讨论】:

你的意思是浏览器上的某个接口可以接受SQL吗? 请您提供更详细的问题描述以及一些示例 JavaScript 对象。 @n8wrl 不,不是接口,它更多的是用于数据的幕后操作,所以我可以接收 javascript 对象(例如来自 ajax 调用)并在之前对它们执行高级查询向用户展示。 @a'r 还没有示例 js 对象,我想知道是否有办法在构建依赖它的解决方案之前查询 js 对象。 【参考方案1】:

试试JSLinq

从网站上查看这个示例:

var myList = [
        FirstName:"Chris",LastName:"Pearson",
        FirstName:"Kate",LastName:"Johnson",
        FirstName:"Josh",LastName:"Sutherland",
        FirstName:"John",LastName:"Ronald",
        FirstName:"Steve",LastName:"Pinkerton"
        ];

var exampleArray = JSLINQ(myList)
                   .Where(function(item) return item.FirstName == "Chris"; )
                   .OrderBy(function(item)  return item.FirstName; )
                   .Select(function(item) return item.FirstName; );

【讨论】:

从未听说过这个,但我喜欢它的外观。不过似乎没有加入。 好吧,有人在他们的网站上声称他开发了类似的东西,不知道它是否属实,但您可以尝试与他联系。见以下链接:jslinq.codeplex.com/discussions/41842?ProjectName=jslinq【参考方案2】:

SQLike 也可以很好地模拟 SQL 或 linq 语法:

http://code.google.com/p/sqlike/

【讨论】:

【参考方案3】:

以前从未使用过它,但在 Google 上快速搜索会得到 LINQ to Javascript。虽然它不是 SQL 语法,但它允许您在 Javascript 对象上执行类似 SQL 的操作,或者看起来如此。你可能还想看看这个question about LINQ and Javascript

【讨论】:

【参考方案4】:

您可以使用async-linq,它支持 JavaScript 中的同步和异步 LINQ 操作,并且功能与 C# 版本相当。您可以通过npm install async-linq获取。

同步操作

linq([1, 2, 3, 4, 5, 6, 7, 8, 9, 0])
    .where(function (v)  return v % 2 === 1; )
    .select(function (v)  return v * 100; )
    .run();

异步操作

linq(['abc.txt', 'def.txt', 'xyz.txt'])
    .async
    .select(function (filename, index, callback) 
        fs.stat(filename, function (err, stat) 
            callback(err, err ? null : 
                filename: filename,
                size: stat.size
            );
        );
    )
    .run(function (err, result) 
        console.log(result);
    );

【讨论】:

【参考方案5】:

有 TrimQuery - 已经有一段时间没有更新了,但它很可靠。 http://code.google.com/p/trimpath/wiki/TrimQuery

【讨论】:

以上是关于使用 SQL 查询 javascript 对象? [关闭]的主要内容,如果未能解决你的问题,请参考以下文章

JavaScript 使用javascript进行sql查询

使用 Javascript 显示 SQL 查询的结果

同时触发javascript和sql查询[重复]

使用javascript的sql查询

BigQuery JavaScript UDF 使用 SQL 查询中的值调用数组

Coldfusion查询到对象树