tupaiopiao 2022-01-22 11:02 采纳率: 80.3%
浏览 68
已结题

oracle数据库亿级数据量中查询

在某个数据中心提供的表中有5亿条数据,就三个字段,身份证,账号,子账号,而且似乎没有建立索引,因为使用身份证单查一条数据都要两三分钟,count一下也要三四分钟。请问怎么提升查询速度,我们不能修改对方的表,只有读权限

  • 写回答

2条回答 默认 最新

  • DarkAthena ORACLE应用及数据库设计方案咨询师 2022-01-22 14:32
    关注

    只在查询上加速的话,目前看上去只能加个并行试试了

    select /*+ parallel(t,8)*/ * from 表名 t where t.身份证号='43000000000000000000'
    

    还有,可以让对方刷新一下这个表的统计信息。
    另外,如果能把这个表同步到另一个数据库,那么就可以建立索引了。
    而且看你这个表结构的设计,看上去应该不是一个表,主键看上去是在子账号上,同一个身份证号应该可能对应多条数据,所以这可能是一个视图,速度慢应该是由于视图内sql逻辑比较复杂或者关联了多个表,并且身份证号应该是在账号表后面的一个属性字段,你用子账号去查可能会比用身份证号去查要快

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 2月1日
  • 已采纳回答 1月24日
  • 创建了问题 1月22日

悬赏问题

  • ¥15 CARSIM前车变道设置
  • ¥50 三种调度算法报错 有实例
  • ¥15 关于#python#的问题,请各位专家解答!
  • ¥200 询问:python实现大地主题正反算的程序设计,有偿
  • ¥15 smptlib使用465端口发送邮件失败
  • ¥200 总是报错,能帮助用python实现程序实现高斯正反算吗?有偿
  • ¥15 对于squad数据集的基于bert模型的微调
  • ¥15 为什么我运行这个网络会出现以下报错?CRNN神经网络
  • ¥20 steam下载游戏占用内存
  • ¥15 CST保存项目时失败