首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

从TypeORM中的列名数组中查找列的where结果

TypeORM是一个开源的对象关系映射(ORM)库,用于在Node.js和浏览器中与数据库进行交互。它支持多种数据库系统,包括MySQL、PostgreSQL、SQLite、Microsoft SQL Server等。

在TypeORM中,可以使用getRepository方法获取实体的存储库(repository),然后使用存储库的方法进行数据库操作。要从列名数组中查找列的where结果,可以使用存储库的find方法,并在where条件中指定列名数组。

以下是一个示例代码:

代码语言:txt
复制
import { Entity, Column, PrimaryGeneratedColumn, createConnection } from "typeorm";

@Entity()
class User {
  @PrimaryGeneratedColumn()
  id: number;

  @Column()
  name: string;

  @Column()
  age: number;
}

async function findColumnByNames(columnNames: string[]): Promise<User[]> {
  const connection = await createConnection({
    type: "mysql",
    host: "localhost",
    port: 3306,
    username: "root",
    password: "password",
    database: "database",
    entities: [User],
    synchronize: true,
  });

  const userRepository = connection.getRepository(User);
  const users = await userRepository.find({
    where: columnNames.map((columnName) => ({ [columnName]: Not(IsNull()) })),
  });

  await connection.close();

  return users;
}

// 调用示例
const columnNames = ["name", "age"];
findColumnByNames(columnNames)
  .then((users) => {
    console.log(users);
  })
  .catch((error) => {
    console.error(error);
  });

在上述示例中,我们定义了一个User实体,包含idnameage三个列。findColumnByNames函数接受一个列名数组作为参数,并使用getRepository方法获取User实体的存储库。然后,我们使用存储库的find方法,并在where条件中使用columnNames.map方法生成列名的查询条件。最后,通过调用findColumnByNames函数并传入列名数组,可以获取到符合条件的用户列表。

推荐的腾讯云相关产品:腾讯云数据库(TencentDB),提供了多种数据库引擎和存储类型,适用于各种应用场景。您可以通过以下链接了解更多信息:

请注意,以上答案仅供参考,具体的解决方案可能因实际情况而异。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

查找数组重复数字

题目来源于《剑指Offer》面试题3:找出数组重复数字。   // 题目:在一个长度为n数组所有数字都在0到n-1范围内。...数组某些数字是重复,但不知道有几个数字重复了,   // 也不知道每个数字重复了几次。请找出数组任意一个重复数字。...此处介绍自己一个做法,以空间换时间,通过新建数组来实现快速查找,具体做法是新建长度为length数组newArray,初始化值为-1;将numbers数组值依次作为newArray下标和对应值为...: (输出) 数组一个重复数字 // 返回值: // true - 输入有效,并且数组存在重复数字 // false - 输入无效,或者数组没有重复数字...numbers, sizeof(numbers) / sizeof(int), duplications, sizeof(duplications) / sizeof(int), true); } // 数组存在多个重复数字

3.9K60

Pandas如何查找中最大值?

一、前言 前几天在Python白银交流群【上海新年人】问了一个Pandas数据提取问题,问题如下:譬如我要查找中最大值,如何做? 二、实现过程 这里他自己给了一个办法,而且顺便增加了难度。...print(df[df.点击 == df['点击'].max()]),方法确实是可以行得通,也能顺利地解决自己问题。...顺利地解决了粉丝问题。 三、总结 大家好,我是皮皮。这篇文章主要盘点了一个Pandas数据提取问题,文中针对该问题,给出了具体解析和代码实现,帮助粉丝顺利解决了问题。...最后感谢粉丝【上海新年人】提出问题,感谢【瑜亮老师】给出思路,感谢【莫生气】、【添砖java】、【冯诚】等人参与学习交流。

22110

查找数组第K大元素

分治算法示例 使用分治算法查找数组第 K 大元素是一种高效方法,其时间复杂度为 O(n)。...2.选择子数组(Select Subarray):根据分解步骤得到数组和枢纽元素位置,确定要继续查找数组。...如果 K 大元素位置在枢纽元素右侧,那么在右侧数组中继续查找;如果在左侧,那么在左侧数组查找。3.递归(Recursion):递归地在所选子数组查找第 K 大元素。...这个过程会反复进行,直到找到第 K 大元素或确定它在左侧或右侧数组。4.合并(Combine):合并步骤通常不需要执行,因为在递归过程,只需继续查找左侧或右侧数组第 K 大元素。...findKthLargest 函数使用了分治算法,通过递归地在子数组查找第 K 大元素,直到找到或确定其在左侧或右侧数组

15120

算法-二维数组查找

问题: 在一个二维数组,每一行元素都按照从左到右递增顺序排序,每一元素都按照从上到下递增顺序排序。实现一个查找功能函数,函数输入为二维数组和一个整数,判断数组是否含有该整数。...要查找数组7在不在数组内,根据前人总结出来规律,我们可以这样做: 选择数组右上角点开始比较,此时该值为9,9>7,同时9还是第四最小数字,那么这意味着,第四都不可能找到7,于是我们可以直接删除第四...绿色代表所在行或者已经排查完了,红色代表当前值。此时值为8,显然和之前结果一样。 ?...这个思路关键地方在于右上角点选取,因为这个点值是所在最小值和所在行最大值,这就意味着: 要查找数值如果比右上角值大,那么它将大于整个行; 要查找数值比如果右上角值小,那么它将小于整个...matrix[row * columns + column]不就是对应二维数组第row行,第column那个数么。

1.4K100

查找某个元素在数组对应索引

1 问题 已知一个数组内元素为 { 19, 28, 37, 46, 50 } 。用户输入一个数据,查找该数据在数组索引,并在控制台输出找到索引值,如果没有查找到,则输出 -1。...2 方法 首先定义一个数组,在键盘录入要查找数据,用一个变量接收。再定义一个变量,初始值为-1。遍历数组获取数组每一个元素。...然后将键盘输入数据和数组每一个元素进行比较,如果值相同就把该值对应索引赋值给索引变量,并结束循环。最后输8出索引变量。...; }else{ System.out.println("您输入数字" + a + "在数组索引是:" + dataIndex); } }...if(a == arr[i]){ return i; } } return -1; } } 3 结语 针对查找某个元素再数组对应索引这个问题

3.1K10

如何查找递增连续数组缺失数字

在一个长度为n递增数组,数组中元素范围是0 ~ n-1,如何在这个递增连续数组查找缺失数字? 分析下: 1. 排序数组搜索算法,首先想到就是二分法查找 2....丢失数字之前左子数组:nums[m] = m, 需要找到第一个nums[m] > m数组索引值即可....继续计算m指针值,m= (l + r)/2=(5 + 5)/2=5; 这时发现左,,右三指针都指向了num[4], 但4并不是我们想要值....在处理边界值时候,在(i == r)时候,还多需要多遍历一次,向右移动左指针一次. 4. 这时,左指针值便是最后想要值. 所以我们遍历条件为(l<=r),最后左指针位置即为缺失结果值....综上,对于有序数组查找,一般都会使用二分法查找.在查找数据时候,注意左右边界指针移动.以及遍历标记(l<=j)即可.

3.1K21

漫画:“旋转数组二分查找

上周一,小灰分享了最最基础二分查找算法,没看过小伙伴可以点击下面链接: 漫画:什么是二分查找?(修订版) 文章最后,小灰遗留了一个问题: 在一个旋转有序数组,如何查找一个整数呢? ?...注意这里有一个前提:我们并不直接知道给定数组旋转点。 如何解决呢?今天让我们来做详细介绍: ? ? ? ? 是哪三种结果呢?...我们这里规定,假设旋转有序数组恢复为普通有序数组,位于普通有序数组第一个位置元素,就是旋转数组旋转点。 直白地说,旋转点就是旋转数组中最小元素: ?...那么,当我们选择中位数,进行一次二分查找时候,会出现哪些结果呢?仅仅从中位数与旋转点相对位置来看,有两种结果: 情况A,旋转点在中位数右侧: ?...由于查找目标出现在右侧条件已经确定,那么出现在左侧条件判断就简单了: !(中位数 < 查找目标 <= 最右侧元素) 综上,我们总结了旋转数组二分查找可能出现四种情况。 ? ? ? ? ?

91610

剑指offer:二维数组查找

每道题会提供简单思路以及测试通过代码 题目描述 在一个二维数组(每个一维数组长度相同),每一行都按照从左到右递增顺序排序,每一都按照从上到下递增顺序排序。...请完成一个函数,输入这样一个二维数组和一个整数,判断数组是否含有该整数。...注:点击左下角阅读原文可以直达原文提交你代码 解答思路 一种简单方法就是整个数组都遍历,当然,数组从左到右,从上到下都是有序,如果你遍历整个数组的话,那就浪费了数组局部有序性了。...如果我们 row = 0 和col = 0开始遍历的话,发现右边数比 array[row][col] 大,而下边也比 array[row][col]大,这样的话,貌似局部有序性没有派上用场。...实际上我们数组左下角开始遍历的话,如果 array[row][col] > target,则往上移动,如果array[row][col] < target,则往右移动,否则找到目的数。

55320

JavaScript算法题:查找数字在数组索引

我们必须对数字数组进行升序排序,并找出给定数字在该数组位置。 算法说明 将值(第二个参数)插入到数组(第一个参数),并返回其在排序后数组最低索引。返回值应该是一个数字。...示例/测试用例:我们不知道输入数组是以哪种方式排序,但是提供测试用例清楚地表明,输入数组应该从小到大进行排序。 请注意,在最后一个测试用例存在边界问题,其中输入数组是一个空数组。...我们目标是将输入数字在输入数组后中排序后,再返回它索引。 示例/测试用例:我们不知道输入数组是以哪种方式排序,但是提供测试用例清楚地表明,输入数组应该从小到大进行排序。...这个解决方案需要考虑两个边界情况: 如果输入数组为空,则我们需要返回 0,因为 num 将是该数组唯一元素,所以它在索引为 0 位置。...让我们看看.findIndex() 并了解它将如何帮助解决这一挑战: .findIndex() 返回数组第一个满足条件元素索引。否则它将返回 -1,这表示没有元素通过测试。

2K20

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券