RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 779326
Accepted
Alexander Kozlov
Alexander Kozlov
Asked:2020-02-02 21:44:14 +0000 UTC2020-02-02 21:44:14 +0000 UTC 2020-02-02 21:44:14 +0000 UTC

如何为oracle选择正确的主键

  • 772

告诉我如何正确确定主键,以应对需要最快插入的情况。唯一行标识符表示如下:'ID:domain.local-46424-1507204866234-1:1:187331:1:1'。插入算法本身以如下形式呈现: 1. 搜索base中是否已经存在具有指定标识符的行(该行的select语句) 2. 如果该行不存在,则进行插入

建议组织表格的最佳方式:

  1. 将像 'ID:domain.local-46424-1507204866234-1:1:187331:1:1' 这样的字符串作为主键。我想这不是最快的方法。
  2. 将主键设为数字自增。添加一个数字列作为字符串的 hashCode,在其上创建索引并在其上进行搜索。实现在应用程序级别检查字符串标识符以防 hashCode 冲突的逻辑
  3. 从 hashCode(str_id) 和 str_id 列中创建一个复合主键。在这种情况下,冲突检查将在数据库级别进行。考虑到在这两个主键列上创建索引,问题是它会有多昂贵。
  4. 也许有更简单的方法?
sql
  • 2 2 个回答
  • 10 Views

2 个回答

  • Voted
  1. MaxU - stop genocide of UA
    2020-02-02T21:52:41Z2020-02-02T21:52:41Z

    在这里进行了有趣的测试-阅读

    SEQUENCE- 可能是最快的选择,但产生更多的 REDO,与SYS_GUID()

    一般来说,无论如何,如果您没有自然候选人,我会在这两个选项之间进行选择 - 即 包含数据的故意唯一列(不是人为的,如SEQUENCEor SYS_GUID())

    • 1
  2. Best Answer
    Alexander Kozlov
    2020-02-02T22:21:40Z2020-02-02T22:21:40Z

    决定听从迈克的建议。

    总而言之,决定使用以下选项作为解决方案:将主键设为数字自动增量。添加一个数字列作为字符串的 hashCode,在其上创建索引并在其上进行搜索。为 hashCode 冲突的 WHERE 子句添加字符串 ID 检查逻辑:

    SELECT * FROM TABLE WHERE hashCode=XX and Code=YY

    感谢所有参与者的帮助,感谢 MaxU 提供的有用信息!:)

    • 0

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    是否可以在 C++ 中继承类 <---> 结构?

    • 2 个回答
  • Marko Smith

    这种神经网络架构适合文本分类吗?

    • 1 个回答
  • Marko Smith

    为什么分配的工作方式不同?

    • 3 个回答
  • Marko Smith

    控制台中的光标坐标

    • 1 个回答
  • Marko Smith

    如何在 C++ 中删除类的实例?

    • 4 个回答
  • Marko Smith

    点是否属于线段的问题

    • 2 个回答
  • Marko Smith

    json结构错误

    • 1 个回答
  • Marko Smith

    ServiceWorker 中的“获取”事件

    • 1 个回答
  • Marko Smith

    c ++控制台应用程序exe文件[重复]

    • 1 个回答
  • Marko Smith

    按多列从sql表中选择

    • 1 个回答
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Suvitruf - Andrei Apanasik 什么是空? 2020-08-21 01:48:09 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5