搜索
首页web前端js教程QueryBuilder 实践第 1 部分

QueryBuilder in Action Part 1

一般使用 Node.js 或专门使用 Total.js 构建应用程序时,高效查询和管理数据至关重要。在本博客中,我们将介绍如何使用 Total.js QueryBuilder 执行基本数据操作。第一部分将介绍基本概念,演示插入和检索数据等核心操作,并展示实际示例以帮助您入门。

入门:探索 Total.js 中的 QueryBuilder

Total.js 的 QueryBuilder 提供了一个强大的抽象层,用于通过过滤、插入、更新和检索数据等操作与各种数据库进行交互。无论您是在开发轻量级应用程序还是管理复杂查询,QueryBuilder 都为 Node.js 应用程序提供了简单而灵活的 ORM 解决方案。

数据库支持和实施

QueryBuilder 充当中间层,抽象数据库引擎的细节。为了有效地利用它,您需要集成现有的实现或构建您自己的以满足您的要求。 Total.js 支持多种数据库引擎,确保不同用例的灵活性。

以下是当前可用的实现:

  • NoSQL 嵌入式数据库 (TextDB): 这是 Total.js 核心中包含的一个轻量级、基于文件的数据库,非常适合小型应用程序或原型设计。
  • PostgreSQL: 将 QueryBuilder 与最强大、功能最丰富的关系数据库之一结合使用。
  • MySQL: 与这个广泛使用的数据库集成,以获得可扩展的高性能解决方案。
  • SQLite: 利用 QueryBuilder 和这个轻量级、无服务器数据库来快速部署或嵌入式应用程序。

设置查询生成器

在本指南中,我们将从嵌入式 NoSQL (TextDB) 数据库开始,演示如何定义模式并执行查询、插入和更新数据等基本操作。最后,您将具备针对其他支持的数据库引擎调整这些操作的技能。

设置数据库

为了有效学习,我们将使用示例用户数据创建一个测试 NoSQL 数据库文件。

数据库设置:创建一个databases/users.nosql 文件来存储示例用户记录:

{"id": 2, "name": "Bob", "age": 30}
{"id": 3, "name": "Charlie", "age": 28}
{"id": 4, "name": "Diana", "age": 22}
{"id": 5, "name": "Edward", "age": 35}
{"id": 6, "name": "John", "age": 45}
{"id": 7, "name": "Fiona", "age": 27}
{"id": 8, "name": "George", "age": 29}
{"id": 9, "name": "Hannah", "age": 24}
{"id": 10, "name": "Isaac", "age": 31}
{"id": 11, "name": "Julia", "age": 26}

很高兴知道:您不需要在数据库文件夹中手动创建 .nosql 文件。如果它不存在,框架能够在插入操作期间创建它。但.nosql 文件内容是明文,了解其结构很重要。也许它对于修复某些情况会有用。

模式定义:使用 schemas/users.js 中的操作创建模式。我们将定义列出、检索和插入用户的操作。

带有实际示例的基本 QueryBuilder 操作

在 schemas/users.js 中,我们将定义列出和插入用户的操作。此架构使用 QueryBuilder 方法来过滤数据、检索特定记录并向数据库添加新用户。

1。使用过滤器列出用户
我们首先定义一个列表操作来根据姓名或年龄等条件检索用户。

{"id": 2, "name": "Bob", "age": 30}
{"id": 3, "name": "Charlie", "age": 28}
{"id": 4, "name": "Diana", "age": 22}
{"id": 5, "name": "Edward", "age": 35}
{"id": 6, "name": "John", "age": 45}
{"id": 7, "name": "Fiona", "age": 27}
{"id": 8, "name": "George", "age": 29}
{"id": 9, "name": "Hannah", "age": 24}
{"id": 10, "name": "Isaac", "age": 31}
{"id": 11, "name": "Julia", "age": 26}

使用示例:

以下是使用列表过滤用户的一些变体。

  • 按名称过滤
NEWSCHEMA('Users', function(schema) {

    schema.action('list', {
        name: 'List users',
        query: 'page:Number, sort:String, name:String',
        params: 'id:String',
        action: async function($) {
            // Example: filter by name
            var users = await DATA.find('nosql/users').where('name', $.query.name).promise();
            $.callback(users); 
        }
    });
});
  • 仅检索第一个用户
var users = await ACTION('Users/list').where('name', 'John').promise();
console.log(users);

2。通过 ID 检索用户
另一个有用的功能是通过 ID 检索用户。使用 QueryBuilder 的 .id() 方法使这变得简单:

var user = await DATA.find('nosql/users').first().promise();
console.log(user);

用法示例

var builder = DATA.find('nosql/users');
builder.id($.params.id);
// or builder.where('id', $.params.id);
$.callback(await builder.promise());

3。插入新用户
接下来,让我们定义一个插入操作以将新用户添加到数据库中。

var user = await ACTION('Users/list').params({ id: 5 }).promise();
console.log(user);  // Retrieves user with id 5

此操作将用户添加到databases/users.nosql。以下是调用插入操作的方法。

使用示例:

schema.action('insert', {
    name: 'Inserting new users',
    input: '*name:String, age:Number',
    output: 'success:Boolean',
    action: function($, model) {
        DATA.insert('nosql/users', model).callback(function(err) {
            if (err) {
                console.error(err);
            } else {
                $.success(true);
            }
        });
    }
});

实际使用案例:QueryBuilder 的实际应用

1。按过滤后的名称检索用户

// in `definitions/test.js`
ON('ready', function() {
  var result = await ACTION('Users/insert', { name: 'Alice', age: 25 }).promise();
    console.log(result);
});

2。通过ID检索用户

async function getUsersByName() {
    var users = await ACTION('Users/list').query({ name: 'Hannah' }).promise();
    console.log(users);
}
getUsersByName();

3。插入新用户并检索更新的列表

async function getUserByID() {
    var user = await ACTION('Users/list').params({ id: 4 }).promise();
    console.log(user);
}
getUserByID();

结论

在 QueryBuilder 实际操作的第一部分中,我们介绍了基本知识:创建基本的 NoSQL 数据库、定义架构操作以及使用 QueryBuilder 方法列出、筛选、检索和插入用户。我们探索了每个操作的实用代码示例,以帮助您了解这些概念在现实场景中的工作原理。
在下一部分中,我们将深入研究更高级的 QueryBuilder 方法和复杂的过滤,为您提供在 Total.js 中有效管理数据的完整工具包。
请继续关注《操作第 2 部分》中的 QueryBuilder,我们将深入探讨高级查询技术来增强您的 Total.js 应用程序!

以上是QueryBuilder 实践第 1 部分的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
Python vs. JavaScript:选择合适的工具Python vs. JavaScript:选择合适的工具May 08, 2025 am 12:10 AM

选择Python还是JavaScript取决于项目类型:1)数据科学和自动化任务选择Python;2)前端和全栈开发选择JavaScript。Python因其在数据处理和自动化方面的强大库而备受青睐,而JavaScript则因其在网页交互和全栈开发中的优势而不可或缺。

Python和JavaScript:了解每个的优势Python和JavaScript:了解每个的优势May 06, 2025 am 12:15 AM

Python和JavaScript各有优势,选择取决于项目需求和个人偏好。1.Python易学,语法简洁,适用于数据科学和后端开发,但执行速度较慢。2.JavaScript在前端开发中无处不在,异步编程能力强,Node.js使其适用于全栈开发,但语法可能复杂且易出错。

JavaScript的核心:它是在C还是C上构建的?JavaScript的核心:它是在C还是C上构建的?May 05, 2025 am 12:07 AM

javascriptisnotbuiltoncorc; saninterpretedlanguagethatrunsonenginesoftenwritteninc.1)javascriptwasdesignedAsalightweight,解释edganguageforwebbrowsers.2)Enginesevolvedfromsimpleterterterpretpreterterterpretertestojitcompilerers,典型地提示。

JavaScript应用程序:从前端到后端JavaScript应用程序:从前端到后端May 04, 2025 am 12:12 AM

JavaScript可用于前端和后端开发。前端通过DOM操作增强用户体验,后端通过Node.js处理服务器任务。1.前端示例:改变网页文本内容。2.后端示例:创建Node.js服务器。

Python vs. JavaScript:您应该学到哪种语言?Python vs. JavaScript:您应该学到哪种语言?May 03, 2025 am 12:10 AM

选择Python还是JavaScript应基于职业发展、学习曲线和生态系统:1)职业发展:Python适合数据科学和后端开发,JavaScript适合前端和全栈开发。2)学习曲线:Python语法简洁,适合初学者;JavaScript语法灵活。3)生态系统:Python有丰富的科学计算库,JavaScript有强大的前端框架。

JavaScript框架:为现代网络开发提供动力JavaScript框架:为现代网络开发提供动力May 02, 2025 am 12:04 AM

JavaScript框架的强大之处在于简化开发、提升用户体验和应用性能。选择框架时应考虑:1.项目规模和复杂度,2.团队经验,3.生态系统和社区支持。

JavaScript,C和浏览器之间的关系JavaScript,C和浏览器之间的关系May 01, 2025 am 12:06 AM

引言我知道你可能会觉得奇怪,JavaScript、C 和浏览器之间到底有什么关系?它们之间看似毫无关联,但实际上,它们在现代网络开发中扮演着非常重要的角色。今天我们就来深入探讨一下这三者之间的紧密联系。通过这篇文章,你将了解到JavaScript如何在浏览器中运行,C 在浏览器引擎中的作用,以及它们如何共同推动网页的渲染和交互。JavaScript与浏览器的关系我们都知道,JavaScript是前端开发的核心语言,它直接在浏览器中运行,让网页变得生动有趣。你是否曾经想过,为什么JavaScr

node.js流带打字稿node.js流带打字稿Apr 30, 2025 am 08:22 AM

Node.js擅长于高效I/O,这在很大程度上要归功于流。 流媒体汇总处理数据,避免内存过载 - 大型文件,网络任务和实时应用程序的理想。将流与打字稿的类型安全结合起来创建POWE

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

VSCode Windows 64位 下载

VSCode Windows 64位 下载

微软推出的免费、功能强大的一款IDE编辑器