RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1118360
Accepted
Pavel
Pavel
Asked:2020-05-01 00:07:00 +0000 UTC2020-05-01 00:07:00 +0000 UTC 2020-05-01 00:07:00 +0000 UTC

索引条件

  • 772

有一个带有索引的表需要修改,以便它也type以这样的方式限制字段,它只能type取三个值LONG,,,。SHORTUNIVERSAL

根据规则:任何一个字符串都必须UNIVERSAL通过组合没有重复symbol_id, account_id, enabled。或允许一LONG、一SHORT为组合symbol_id, account_id, enabled。

或者换句话说symbol_id, account_id, enabled,它enabled == TRUE可以是一个独特的组合:

  1. 一个通用实例(UNIVERSAL这意味着它既可以工作又可以如何工作LONG)SHORT。

  2. 两个实例,一个LONG和一个SHORT。

  3. 每个实例至少有一个LONG,或者SHORT应该有true

LONG, 并且SHORT可以单独存在, 即例如LONG有, 但SHORT没有, 没有计划. 或相反亦然。

-- Instances
CREATE TABLE IF NOT EXISTS instances
(
    id            BIGSERIAL PRIMARY KEY,
    enabled       BOOLEAN      NOT NULL,
    title         VARCHAR(255) NOT NULL,
    type          VARCHAR(255) NOT NULL,
    status        VARCHAR(255) NOT NULL,
    updated_at    TIMESTAMP NOT NULL,
    last_callback TIMESTAMP,
    settings      VARCHAR(255),
    user_id       BIGINT REFERENCES users (id),
    symbol_id     BIGINT REFERENCES symbols (id),
    account_id    BIGINT REFERENCES accounts (id),
    strategy_id   BIGINT REFERENCES strategies (id)
);

和索引:

CREATE UNIQUE INDEX ui_symbol_account_enabled
    ON instances (symbol_id, account_id, enabled)
    WHERE (enabled IS TRUE);

它可能应该是这样的:

CREATE UNIQUE INDEX ui_symbol_account_enabled_type
    ON instances (symbol_id, account_id, enabled, type)
    WHERE (enabled IS TRUE
        AND (type = 'UNIVERSAL' OR type = 'SHORT' OR type = 'LONG')
        );

仅不是三个值之一,而是根据上述规则。如何正确书写?

sql
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    Ainar-G
    2020-05-01T02:00:09Z2020-05-01T02:00:09Z

    如果架构更改是可以接受的,那么我建议这个(简化的)选项:

    CREATE TABLE t_1 (
      symbol_id  BIGINT  NOT NULL
    , account_id BIGINT  NOT NULL
    , enabled    BOOLEAN NOT NULL
    , long       BOOLEAN NOT NULL
    , short      BOOLEAN NOT NULL
    , CHECK (long OR short)
    )
    ;
    
    CREATE UNIQUE INDEX
        ON t_1(symbol_id, account_id)
     WHERE (enabled AND short)
    ;
    
    CREATE UNIQUE INDEX
        ON t_1(symbol_id, account_id)
     WHERE (enabled AND long)
    ;
    

    因此,您的类型'UNIVERSAL'变成满足条件的记录long AND short。


    如果无法更改方案,则:

    CREATE UNIQUE INDEX
        ON t_1(symbol_id, account_id)
     WHERE (enabled AND type IN ('UNIVERSAL', 'LONG'))
    ;
    
    CREATE UNIQUE INDEX
        ON t_1(symbol_id, account_id)
     WHERE (enabled AND type IN ('UNIVERSAL', 'SHORT'))
    ;
    
    • 1

相关问题

  • 通过 OUT 参数从过程结果输出

  • ON 关键字附近的语法错误 - SQL

  • 多表查询中的 Count() 聚合函数

  • 根据时间更改单元格中的日期

  • phpMyAdmin 中的错误 #1064 SQL 查询

  • Qt:包含变量的数据库查询

Sidebar

Stats

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

    如何从列表中打印最大元素(str 类型)的长度?

    • 2 个回答
  • Marko Smith

    如何在 PyQT5 中清除 QFrame 的内容

    • 1 个回答
  • Marko Smith

    如何将具有特定字符的字符串拆分为两个不同的列表?

    • 2 个回答
  • Marko Smith

    导航栏活动元素

    • 1 个回答
  • Marko Smith

    是否可以将文本放入数组中?[关闭]

    • 1 个回答
  • Marko Smith

    如何一次用多个分隔符拆分字符串?

    • 1 个回答
  • Marko Smith

    如何通过 ClassPath 创建 InputStream?

    • 2 个回答
  • Marko Smith

    在一个查询中连接多个表

    • 1 个回答
  • Marko Smith

    对列表列表中的所有值求和

    • 3 个回答
  • Marko Smith

    如何对齐 string.Format 中的列?

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +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