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日