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 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵