使用 TypeORM 的 Raw SQL 实现灵活的 Where 查询条件

使用 typeorm 的 raw sql 实现灵活的 where 查询条件

本文旨在介绍如何在 TypeORM 中使用 Raw SQL 表达式来构建更灵活的 Where 查询条件,尤其是在需要避免大量 Or 条件时。通过 Raw 函数,你可以直接在 TypeORM 的查询选项中嵌入原生 SQL 片段,从而实现更精细的查询控制,避免构建过于庞大的 Where 数组,提升代码可读性和性能。

TypeORM 提供了多种方式来构建查询条件,但有时我们需要更底层的控制,或者需要避免构建过于复杂的查询对象。这时,Raw SQL 表达式就派上了用场。 Raw 允许你直接在 TypeORM 的 find 方法的 where 选项中嵌入原生 SQL 片段,从而实现更精细的查询控制。

使用 Raw SQL 表达式

Raw 函数接受一个函数作为参数,该函数接收一个别名(alias)作为参数,并返回一个 SQL 字符串。这个 SQL 字符串会被直接插入到生成的 SQL 查询语句中。

示例:

假设我们有一个 Post 实体,并且想要查询 currentDate 大于某个日期的所有记录。我们可以使用以下代码:

import { DataSource, Raw } from "typeorm";// 假设 dataSource 已经初始化async function findPostsAfterDate(dataSource: DataSource, date: string) {  const loadedPosts = await dataSource.getRepository("Post").findBy({    currentDate: Raw((alias) => `${alias} > :date`, { date: date }),  });  return loadedPosts;}

这段代码将会生成如下 SQL 查询语句:

SELECT * FROM "post" WHERE "currentDate" > '2020-10-06'

参数化查询:

需要注意的是,为了避免 SQL 注入,你应该始终使用参数化查询。在 Raw 函数的第二个参数中,你可以传递一个包含参数的 JavaScript 对象。这些参数会被安全地转义并插入到 SQL 查询语句中。

应用场景:避免大量 Or 条件

回到最初的问题,如果我们需要根据 availableFrom 和 availableTo 字段来筛选数据,并且想要避免使用大量的 Or 条件,我们可以使用 Raw SQL 表达式来实现。

假设我们有如下需求:

useAvailablePeriod 为 true 时,需要满足 availableFrom = currentDate,或者 availableFrom 或 availableTo 为 NULL。useAvailablePeriod 为 false 时,不需要考虑 availableFrom 和 availableTo 字段。

我们可以使用以下代码来实现:

import { DataSource, Raw, LessThanOrEqual, NewsStatus } from "typeorm";interface Params {  categorySeoName: string;}// 假设 dataSource 已经初始化async function findNews(dataSource: DataSource, params: Params) {  const currentDate = new Date();  const newsRepository = dataSource.getRepository("News");  const [news, count] = await newsRepository.findAndCount({    select: {      id: true,      publishedAt: true,      isDisplayed: true,      priority: true,      availableTo: true,      availableFrom: true,      useAvailablePeriod: true,    },    where: [      {        status: NewsStatus.PUBLISHED,        newsCategories: { seoName: params.categorySeoName },        useAvailablePeriod: true,        availableFrom: Raw((alias) => `(${alias}  `(${alias} >= :currentDate OR ${alias} IS NULL)`, { currentDate }),        publishedAt: LessThanOrEqual(currentDate),      },      {        status: NewsStatus.PUBLISHED,        newsCategories: { seoName: params.categorySeoName },        useAvailablePeriod: false,        publishedAt: LessThanOrEqual(currentDate),      },    ],    order: { publishedAt: "DESC", priority: "DESC" },  });  return { news, count };}

在这个例子中,我们使用了 Raw 函数来构建 availableFrom 和 availableTo 的查询条件。 这样,我们就可以避免构建大量的 Or 条件,使代码更加简洁易懂。 注意,这里使用了参数化查询,将 currentDate 作为参数传递给 Raw 函数,避免了 SQL 注入的风险。

注意事项:

在使用 Raw SQL 表达式时,务必注意 SQL 注入的风险。始终使用参数化查询,避免直接将用户输入拼接到 SQL 字符串中。Raw SQL 表达式会降低代码的可移植性,因为不同的数据库可能使用不同的 SQL 语法。 尽量避免在业务逻辑中使用过于复杂的 SQL 表达式,以便于将来更换数据库。虽然 Raw SQL 表达式提供了更灵活的查询控制,但也增加了代码的复杂性。 在可以使用 TypeORM 提供的其他查询方式时,尽量避免使用 Raw SQL 表达式。

总结:

Raw SQL 表达式是 TypeORM 提供的一个强大的工具,可以帮助我们构建更灵活的查询条件。 在需要避免大量 Or 条件或者需要使用特定数据库的 SQL 特性时,Raw SQL 表达式是一个不错的选择。 但是,在使用 Raw SQL 表达式时,务必注意 SQL 注入的风险,并尽量避免在业务逻辑中使用过于复杂的 SQL 表达式。

以上就是使用 TypeORM 的 Raw SQL 实现灵活的 Where 查询条件的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1517910.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月20日 11:06:18
下一篇 2025年12月20日 11:06:30

相关推荐

  • 如何利用JavaScript的Promise.race实现超时控制,以及它在网络请求超时处理中的最佳实践?

    利用Promise.race实现超时控制,是让网络请求与定时器赛跑,先完成者胜出。若定时器先触发,则返回超时错误,避免长时间等待。此法虽不能真正取消底层请求,但可及时释放前端逻辑资源,提升用户体验和应用健壮性。结合AbortController能真正终止请求,而自定义错误类、用户提示、重试机制与日志…

    2025年12月20日
    000
  • JavaScript 引擎如何对 Hot Function 进行即时编译优化?

    JavaScript引擎通过动态分析识别高频执行的函数并进行分层优化:首先统计函数调用频率,达到阈值后标记为热点函数;随后进行基线编译,快速生成低级机器码并收集类型反馈;接着利用类型推测进行优化编译,生成高效特化代码;当类型变化导致假设失效时触发去优化,回退至安全执行模式。该机制自动运行,开发者应保…

    2025年12月20日
    000
  • 如何设计一个前端项目的错误边界机制?

    通过分层拦截实现前端容错:1. 使用React错误边界捕获渲染异常,显示降级UI;2. 全局监听onerror和unhandledrejection处理脚本与Promise错误;3. 为资源加载设置fallback机制;4. 统一上报错误至监控系统,提升稳定性和可维护性。 前端项目中,错误边界能防止…

    2025年12月20日
    000
  • 如何利用JavaScript的数组缓冲和视图处理二进制数据,以及它在网络通信或文件解析中的使用?

    JavaScript通过ArrayBuffer提供固定大小的原始二进制内存块,再借助TypedArray或DataView视图以特定类型和字节序读写数据,实现高效处理二进制流,广泛应用于WebSocket通信、文件解析等场景。 JavaScript处理二进制数据,其核心思想是提供一个原始的、固定大小…

    2025年12月20日
    000
  • 如何用JavaScript进行机器学习(使用TensorFlow.js)?

    JavaScript可通过TensorFlow.js在浏览器或Node.js中实现机器学习。1. 通过CDN或npm安装并引入tfjs库;2. 创建线性回归模型,使用tensor1d准备数据,sequential构建网络,compile配置优化器与损失函数,fit训练模型,predict进行预测;3…

    2025年12月20日
    000
  • JavaScript函数式编程的核心概念和实践是什么?

    函数式编程通过纯函数和不可变性提升代码质量,使用高阶函数与函数组合实现声明式编程,如map、filter、reduce操作数据,避免副作用和状态修改,结合ES6+语法和柯里化等技巧,在React等框架中广泛应用,增强可读性与可维护性。 JavaScript函数式编程强调使用纯函数和避免改变状态或可变…

    2025年12月20日
    000
  • 深入理解JavaScript Fetch API的错误处理与封装

    本文旨在探讨如何使用JavaScript的Fetch API进行健壮的网络请求,并有效封装其错误处理逻辑。我们将详细介绍如何利用async/await语法,优雅地处理不同类型的请求失败(如网络错误、非200 HTTP状态码),以及如何根据业务需求返回统一的成功数据或详细的错误信息,同时兼顾文本和JS…

    2025年12月20日
    000
  • 如何实现一个支持依赖预绑定的IoC容器?

    答案:构建支持预绑定的IoC容器需实现服务注册、依赖解析、生命周期管理和延迟注入。首先通过bind方法将接口映射到实现,维护类型与构造函数的绑定关系;接着在实例化时解析构造函数参数,递归注入依赖,支持design:paramtypes反射获取类型信息;同时定义瞬态、单例等生命周期策略,缓存实例以复用…

    2025年12月20日
    000
  • JS 浏览器内存分析 – 使用堆快照识别分离 DOM 与内存泄漏

    首先在基线状态拍下堆快照,执行操作后再拍一张并对比,筛选“Detached”对象,通过引用链定位未释放的DOM元素,找到代码中未清理的引用并修复,从而解决内存泄漏问题。 前端开发中,内存泄漏是个挺让人头疼的问题,尤其是那些你以为已经彻底“消失”的DOM元素,它们可能悄悄地占据着内存,最终拖慢整个应用…

    2025年12月20日
    000
  • 如何构建一个高可用的Node.js RESTful API服务?

    答案:构建高可用Node.js RESTful API需从分层架构、错误处理、水平扩展与监控四方面入手。采用路由、控制器、服务与数据访问分层设计,结合Express/Fastify中间件分离关注点;通过try/catch和事件监听处理异常,使用Winston/Pino日志记录;利用cluster模块…

    2025年12月20日
    000
  • 如何编写安全的JavaScript代码以防止常见的XSS攻击?

    防止XSS的关键是正确处理用户输入输出。应对用户输入进行白名单验证并限制格式,前端后端均需验证;在插入HTML时对动态内容进行HTML编码,转义特殊字符如 防止XSS(跨站脚本攻击)的关键在于正确处理用户输入和输出,确保不可信的数据不会在浏览器中被当作可执行代码运行。以下是编写安全JavaScrip…

    2025年12月20日
    000
  • 如何理解JavaScript中的解构赋值?

    解构赋值是ES6提供的语法糖,能简洁提取数组或对象数据。它提升可读性、简化变量声明,支持默认值、重命名、嵌套解构及剩余元素收集,常用于交换变量、函数参数处理和React的props解构。需注意默认值仅对undefined生效、对象解构时的括号陷阱、数组顺序依赖及深层解构可能引发的错误。它与箭头函数、…

    2025年12月20日
    000
  • 如何用JavaScript实现一个支持实时协同的代码评审工具?

    答案:基于React/Vue和Monaco Editor实现代码展示与差异对比,通过WebSocket实现实时批注同步。前端负责交互体验,后端用Node.js+Socket.IO处理实时通信,数据库存储评论、版本等数据,确保协同一致性。 用JavaScript实现一个支持实时协同的代码评审工具,核心…

    2025年12月20日
    000
  • JavaScript模块循环依赖的根源和解决方案是什么?

    循环依赖的根源在于模块间相互引用导致初始化未完成就被使用。当模块A导入B,B又导入A时,ES6模块因静态解析和绑定机制,可能使一方读取到undefined值。例如a.js与b.js互相导入对方导出的变量,由于执行顺序问题,各自打印出undefined。解决方法包括:1. 重构代码,将共用逻辑提取至独…

    2025年12月20日
    000
  • 如何用现代JavaScript实现一个状态机(State Machine)?

    答案:使用ES6类、Map和异步方法实现状态机,支持状态转换校验与钩子函数。通过定义初始状态、允许的转移路径及事件触发规则,结合constructor初始化配置,can方法校验转换合法性,handle方法执行带前后钩子的异步状态变更,适用于订单等流程控制场景,代码清晰可扩展。 用现代JavaScri…

    2025年12月20日
    000
  • 如何构建一个无依赖的、轻量级的JavaScript状态管理库?

    答案:通过闭包封装状态,提供 getState、setState 和 subscribe API,支持不可变更新与模块化设计,实现轻量级 JavaScript 状态管理。 构建一个无依赖、轻量级的 JavaScript 状态管理库,核心在于提供简单的状态存储、响应式更新和模块化设计,同时避免引入外部…

    2025年12月20日
    000
  • 如何编写符合函数式编程范式的纯净JavaScript代码?

    答案:编写纯净JavaScript代码需使用纯函数、不可变数据和高阶函数。纯函数确保输入输出一致且无副作用,避免依赖或修改外部状态;通过map、filter、reduce等方法操作数组返回新值,利用扩展运算符创建新对象;将函数作为参数传递或返回,组合小函数实现复杂逻辑;副作用如I/O操作应隔离到程序…

    2025年12月20日
    000
  • 为什么说闭包是 JavaScript 中实现数据私有的重要机制之一?

    闭包能实现数据私有,是因为内部函数可访问并保持对外部变量的引用,即使外部函数已执行完毕。如createCounter中count被封闭,仅通过返回函数操作;createUser利用闭包隐藏name和age,提供受控访问;模块模式中用立即执行函数隔离privateData与privateMethod,…

    2025年12月20日
    000
  • JavaScript中的移动端开发有哪些特殊考虑?

    应优先使用touchstart、touchmove等触摸事件替代鼠标事件,以提升移动端交互响应性与操作流畅度。 在JavaScript中进行移动端开发时,需要针对移动设备的特性做出相应调整,以确保应用性能良好、交互自然且兼容性强。以下是几个关键方面的考虑。 触摸事件与手势支持 移动设备主要依赖触摸操…

    2025年12月20日
    000
  • Next.js中集成@svgr/webpack与Turbopack的实战指南

    本教程旨在解决Next.js项目在启用实验性Turbopack时,@svgr/webpack集成过程中出现的SVG解析错误。核心解决方案在于通过配置next.config.js中的experimental.turbo.rules,明确指示Turbopack将经@svgr/webpack处理后的SVG…

    2025年12月20日
    000

发表回复

登录后才能评论
关注微信