首页 > 其他分享 >Find 选项

Find 选项

时间:2024-03-26 11:02:48浏览次数:14  
标签:选项 title find likes WHERE Find SELECT typeorm

Find 选项

基础选项

所有存储库和管理器find方法都接受可用于查询所需数据的特殊选项,而无需使用QueryBuilder

  • select - 表示必须选择对象的哪些属性
userRepository.find({ select: ["firstName", "lastName"] });
 
  • relations - 关系需要加载主体。 也可以加载子关系(join 和 leftJoinAndSelect 的简写)
userRepository.find({ relations: ["profile", "photos", "videos"] });
userRepository.find({ relations: ["profile", "photos", "videos", "videos.video_attributes"] });
 
  • join - 需要为实体执行联接,扩展版对的"relations"。
userRepository.find({
join: {
alias: "user",
leftJoinAndSelect: {
profile: "user.profile",
photo: "user.photos",
video: "user.videos"
}
}
});
 
  • where -查询实体的简单条件。
userRepository.find({ where: { firstName: "Timber", lastName: "Saw" } });
 

查询嵌入实体列应该根据定义它的层次结构来完成。 例:

userRepository.find({ where: { name: { first: "Timber", last: "Saw" } } });
 

使用 OR 运算符查询:

userRepository.find({
where: [{ firstName: "Timber", lastName: "Saw" }, { firstName: "Stan", lastName: "Lee" }]
});
 

将执行以下查询:

SELECT * FROM "user" WHERE ("firstName" = 'Timber' AND "lastName" = 'Saw') OR ("firstName" = 'Stan' AND "lastName" = 'Lee')
 
  • order - 选择排序
userRepository.find({
order: {
name: "ASC",
id: "DESC"
}
});
 

返回多个实体的find方法(findfindAndCountfindByIds),同时也接受以下选项:

  • skip - 偏移(分页)
userRepository.find({
skip: 5
});
 
  • take - limit (分页) - 得到的最大实体数。
userRepository.find({
take: 10
});
 

** 如果你正在使用带有 MSSQL 的 typeorm,并且想要使用takelimit,你必须正确使用 order,否则将会收到以下错误:'FETCH语句中NEXT选项的使用无效。'

userRepository.find({
order: {
columnName: "ASC"
},
skip: 0,
take: 10
});
 
  • cache - 启用或禁用查询结果缓存。 有关更多信息和选项,请参见caching
userRepository.find({
cache: true
});
 
  • lock - 启用锁查询。 只能在findOne方法中使用。 lock是一个对象,可以定义为:
{ mode: "optimistic", version: number|Date }
 

或者

{ mode: "pessimistic_read"|"pessimistic_write"|"dirty_read" }
 

例如:

userRepository.findOne(1, {
lock: { mode: "optimistic", version: 1 }
})
 

find 选项的完整示例:

userRepository.find({
select: ["firstName", "lastName"],
relations: ["profile", "photos", "videos"],
where: {
firstName: "Timber",
lastName: "Saw"
},
order: {
name: "ASC",
id: "DESC"
},
skip: 5,
take: 10,
cache: true
});
 

进阶选项

TypeORM 提供了许多内置运算符,可用于创建更复杂的查询:

  • Not
import { Not } from "typeorm";

const loadedPosts = await connection.getRepository(Post).find({
title: Not("About #1")
});
 

将执行以下查询:

SELECT * FROM "post" WHERE "title" != 'About #1'
 
  • LessThan
import { LessThan } from "typeorm";

const loadedPosts = await connection.getRepository(Post).find({
likes: LessThan(10)
});
 

将执行以下查询:

SELECT * FROM "post" WHERE "likes" < 10
 
  • LessThanOrEqual
import { LessThanOrEqual } from "typeorm";
const loadedPosts = await connection.getRepository(Post).find({
likes: LessThanOrEqual(10)
});
 

将执行以下查询:

SELECT * FROM "post" WHERE "likes" <= 10
 
  • MoreThan
import { MoreThan } from "typeorm";

const loadedPosts = await connection.getRepository(Post).find({
likes: MoreThan(10)
});
 

将执行以下查询:

SELECT * FROM "post" WHERE "likes" > 10
 
  • MoreThanOrEqual
import { MoreThanOrEqual } from "typeorm";
const loadedPosts = await connection.getRepository(Post).find({
likes: MoreThanOrEqual(10)
});
 

将执行以下查询:

SELECT * FROM "post" WHERE "likes" >= 10
 
  • Equal
import { Equal } from "typeorm";

const loadedPosts = await connection.getRepository(Post).find({
title: Equal("About #2")
});
 

将执行以下查询:

SELECT * FROM "post" WHERE "title" = 'About #2'
 
  • Like
import { Like } from "typeorm";

const loadedPosts = await connection.getRepository(Post).find({
title: Like("%out #%")
});
 

将执行以下查询:

SELECT * FROM "post" WHERE "title" LIKE '%out #%'
 
  • ILike
import { ILike } from "typeorm";

const loadedPosts = await connection.getRepository(Post).find({
title: ILike("%out #%")
});
 

将执行以下查询:

SELECT * FROM "post" WHERE "title" ILIKE '%out #%'
 
  • Between
import { Between } from "typeorm";

const loadedPosts = await connection.getRepository(Post).find({
likes: Between(1, 10)
});
 

将执行以下查询:

SELECT * FROM "post" WHERE "likes" BETWEEN 1 AND 10
 
  • In
import { In } from "typeorm";

const loadedPosts = await connection.getRepository(Post).find({
title: In(["About #2", "About #3"])
});
 

将执行以下查询:

SELECT * FROM "post" WHERE "title" IN ('About #2','About #3')
 
  • Any
import { Any } from "typeorm";

const loadedPosts = await connection.getRepository(Post).find({
title: Any(["About #2", "About #3"])
});
 

将执行以下查询: (Postgres notation):

SELECT * FROM "post" WHERE "title" = ANY(['About #2','About #3'])
 
  • IsNull
import { IsNull } from "typeorm";

const loadedPosts = await connection.getRepository(Post).find({
title: IsNull()
});
 

将执行以下查询:

SELECT * FROM "post" WHERE "title" IS NULL
 
  • Raw
import { Raw } from "typeorm";

const loadedPosts = await connection.getRepository(Post).find({
likes: Raw("1 + likes = 4")
});
 

将执行以下查询:

SELECT * FROM "post" WHERE 1 + "likes" = 4
 

注意:注意Raw操作符。 它应该从提供的表达式执行纯 SQL,而不能包含用户输入,否则将导致 SQL 注入。

你还可以将这些运算符与Not运算符组合使用:

import { Not, MoreThan, Equal } from "typeorm";

const loadedPosts = await connection.getRepository(Post).find({
likes: Not(MoreThan(10)),
title: Not(Equal("About #2"))
});
 

将执行以下查询:

SELECT * FROM "post" WHERE NOT("likes" > 10) AND NOT("title" = 'About #2')

标签:选项,title,find,likes,WHERE,Find,SELECT,typeorm
From: https://www.cnblogs.com/sexintercourse/p/18096105

相关文章

  • Find Options
    FindOptionsBasicoptionsAdvancedoptions# BasicoptionsAllrepositoryandmanager .find* methodsacceptspecialoptionsyoucanusetoquerydatayouneedwithoutusing QueryBuilder:select -indicateswhichpropertiesofthemainobjectmustbe......
  • proto3默认值与可选项
    背景介绍目前开发的产品架构采用微服务架构,微服务之间通信的消息格式则使用的proto3标准协议格式。proto介绍全称ProtocolBuffers是Google公司开发的一种数据描述语言,是一种类似 XML但更灵活和高效的结构化数据存储格式,可用于结构化数据的序列化,适用于数据存储、RPC数据交换......
  • EasyUi之Tabs(选项卡)
    原文链接:https://blog.csdn.net/qianbihua00/article/details/115392143什么是Tabs选项卡是最流行的导航模式之一(与菜单栏和垂直导航一样)。选项卡最大的优点是用户很熟悉,而且经常是持久的内容,所以即使用户在网站或应用程序中跳出刚浏览过的内容,他们也不会迷失。官方示例 ......
  • Visual Studio Code 重置“不再询问”选项
    有一次使用VSCode重命名一个Python文件时,VSCode询问“扩展‘Python’希望通过移动此文件来进行重构更改”。当时没有多想,选中“不再提问”之后就点了“确定”。结果后来后悔,觉得在进行更改之前应该先检查一下更改的内容。于是想要重置这个“不再询问”的选项。结果始终没有......
  • portfinder.getPort( { port: 8080, // 默认8080端口,若被占用,重复+1,直到找
    https://github.com/wkylin/pro-sale-charge/blob/df7fa93c8673701e6897f18498cab78a7fbb05d7/webpack/webpack.dev.js#L77C1-L92C3constportfinder=require('portfinder')module.exports=newPromise((resolve,reject)=>{portfinder.getPort(......
  • cmake之find_library使用问题
    附上工程源码demo工程PS:这个工程用于导出库CMakeLists.txtcmake_minimum_required(VERSION3.5)project(demoLANGUAGESCXX)set(CMAKE_INCLUDE_CURRENT_DIRON)set(CMAKE_CXX_STANDARD11)set(CMAKE_CXX_STANDARD_REQUIREDON)add_library(demoSHAREDdemo.cpp......
  • Error: Could not find or load main class org.apache.hadoop.hbase.util.GetJavaPro
    Hbase没有将其自身的依赖包添加到classpath配置路径所以才会导致找不到自身主类的报错vim/usr/local/hbase/bin/hbase 在161行出修改CLASSPATH="${HBASE_CONF_DIR}"CLASSPATH=${CLASSPATH}:$JAVA_HOME/lib/tools.jar:/usr/local/hbase/lib/*修改成功后,不再报错......
  • elFinder的目录映射
     目录映射一级文件夹创建符号连接;选择源链接点在elFinder相应文件夹的空白处右击,选择「创建为」→「符号连接」修改php\\connector.minimal.php文件,新增一个项目卷。大约是在165行之后。修改'path’一行中的路径修改'URL'一行中的路径(与path中的保持一致)//......
  • 开发者选项 选择日志级别 这个是个小米miui特有的选项,aosp里搜了下好像没有
    "Developeroptions""Selectloglevel" https://github.com/ingbrzy/Xiaomi.eu-MIUIv10-XML-Compare/blob/master/sakura/Settings.apk/res/values/strings.xmlhttps://github.com/ingbrzy/Xiaomi.eu-MIUIv11-XML-Compare/blob/master/davinci_stabl......
  • 常用命令find 细则
    常用命令find细则前言find命令在Linux和Unix系统中被广泛使用,用于在目录树中查找文件,并可以对查找到的文件执行指定的操作。以下是find命令的一些常用选项和用法总结:常用选项1.-name:按照文件名查找文件。2.-iname:按照文件名查找文件,不区分大小写。3.-type:......