tupaiopiao 2021-09-25 21:29 采纳率: 80.3%
浏览 13
已结题

oracle中查询效率问题

举个例子,表里有17万条的人物数据,用身份证做索引,在查询的时候需要先获取身份证。
如果要获取一千个人的信息,在获取了身份证的情况下并且身份证放入了list中,用in还是用idcard=x效率高

select * from table where idcard in (idnum1,idnum2,idnum3 -1000)

select * from table where idcard in = idnum1 select * from table where idcard in = idnum2
都是要遍历list的 哪个效率会好,默认全部用大写,省去oracle的编译

  • 写回答

1条回答 默认 最新

  • IT阿沈 2021-09-26 10:03
    关注

    就这两个写法来说, in 的效率会高一点,但也有其他的办法,以提升效率:

    • 将list中的身份证转储至一个临时表中,(以应对之后可能出现的1万甚至10万个身份证查询的情况)
    • 通过 exists 进行两个表的数据关联,获取能和临时表中的身份证号匹配的数据
    • 注意临时表的清空问题
    select * from ID_CARD a  where  exists ( select 1 from id_temp b where a.id = b.id )
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 10月4日
  • 已采纳回答 9月26日
  • 创建了问题 9月25日

悬赏问题

  • ¥15 关于#linux#的问题(输入输出错误):出现这个界面接着我重新装系统,又让修电脑的师傅帮我扫描硬盘(没有问题)用着用着又卡死(相关搜索:固态硬盘)
  • ¥15 cv::resize不同线程时间不同
  • ¥15 web课程,怎么做啊😭没好好听课 根本不知道怎么下手
  • ¥15 做一个关于单片机的比较难的代码,然后搞一个PPT进行解释
  • ¥15 python提取.csv文件中的链接会经常出现爬取失败
  • ¥15 数据结构中的数组地址问题
  • ¥15 maya的mel里,怎样先选择模型A,然后利用mel脚本自动选择有相同名字的模型B呢。
  • ¥15 Python题,根本不会啊
  • ¥15 会会信号与系统和python的来
  • ¥15 关于#python#的问题