V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
awesomePower
V2EX  ›  数据库

mysql 如何针对位运算条件字段进行索引

  •  
  •   awesomePower · 88 天前 · 1401 次点击
    这是一个创建于 88 天前的主题,其中的信息可能已经有所发展或是发生改变。

    如果一个字段需要进行灵活的位运算当成查询条件,怎么对这个字段索引。mysql 不行的话,其他数据库能做到吗

    5 条回复    2024-08-13 07:49:10 +08:00
    encounter2017
        1
    encounter2017  
       88 天前
    pg 支持部分索引,比如:

    CREATE INDEX access_log_client_ip_ix ON access_log (client_ip)
    WHERE NOT (client_ip > inet '192.168.100.0' AND
    client_ip < inet '192.168.100.255');
    andytao
        2
    andytao  
       88 天前
    需要带上 STORED 参数才能索引,虚拟计算的貌似不支持。
    sujin190
        3
    sujin190  
       88 天前
    如果你真是按位查找,从索引设计来说位个数不能很多的话索引效果几乎没有吧,bitmap 这种的话那也没有场景需要存多行吧,否则如果如楼上所说类似 ip 这种转换为大于小于查找就好了啊,索引不是万能的
    rekulas
        4
    rekulas  
       88 天前
    最好说说你的原生需求
    xuanbg
        5
    xuanbg  
       87 天前
    要反过来才行。不是拿字段的值运算后匹配条件,而是条件运算后匹配字段的值,这样就能走索引了。和什么运算方式无关。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2704 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 11:54 · PVG 19:54 · LAX 03:54 · JFK 06:54
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.