gpt4 book ai didi

java - 如何在mybatis中的IN子句中使用超过1000个参数?

转载 作者:行者123 更新时间:2023-11-30 06:08:21 36 4
gpt4 key购买 nike

我使用 Oracle 数据库和 myBatis 作为 ORM 框架,所有查询都在 XML 映射器文件中。我需要在 IN 中放入几千个参数caluse 和我知道有一个限制,即只能放 1000 个参数。我决定解决方案:

WHERE something IN (a1, a2, ..., a1000)
OR something IN (a1001, a1002, ..., a2000)
OR ...

如何在 XML 映射器文件中实现这一点?

<foreach> , <if>标签等,但我没有找到任何合适的可以将上面的SQL代码插入到模板中。

如果像这样的东西能够让它发挥作用那就太好了:

<some_tag collection="huge_collection" item="huge_collection[1:1000]>

</some_tag>

最佳答案

尽管您可以解决 IN 参数的数量:

  1. 数千个绑定(bind)值可能会产生数兆字节的 SQL。将此 SQL 发送到数据库需要很长时间。

  2. 由于SQL解析,效率会很低。解析这么长的 SQL 不仅需要很长时间,而且每个具有不同数量绑定(bind)参数的调用都将被单独解析和规划(参见 this article which explains it )。

  3. SQL 语句中的绑定(bind)参数存在硬性限制。您可以重复OR几次来解决IN限制,但在某些时候您将达到SQL语句限制。

对于这种类型的查询,通常最好创建 temporary tables 。在查询之前创建它,将所有标识符插入其中,并在实际查询中与该临时表连接以模拟 WHERE 语句。

理想情况下,您可以用存储过程替换查询。从数据库中取出数以万计的标识符只是为了在下一个查询中将其传回数据库是低效的。

关于java - 如何在mybatis中的IN子句中使用超过1000个参数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50801339/

36 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com