基于前文,创建索引的时候有一个问题
每个bigint类型包括60个记录的位信息.
但是第0位表示第六十个记录的位
第1位至第59位表示第一至五十九的记录的位信息.
这样记录的位信息保存并不连续,
使用的时候还得把最右边的一位挪到最左边,不好理解还非常麻烦,性能也有损耗.
经过王工的改良,
使用如下sql替换,则保存的位信息就连续了
SELECT
CEIL(id / 60) g60,
CEIL(id / 1200) g1200,
age grouped,
COUNT(*) total,
BIT_OR(1 <
FROM
o_huaxiang_big_0 o
GROUP BY g1200 , g60 , age
创建位图索引的整体SQL如下
truncate table bitmap20_0;
insert into bitmap20_0
select
'o_huaxiang_big' table_name,
'umc_sex' column_name,
((g1200-1)*60)*20 min_id,
((g1200-1)*60)*20+1200 max_id,
v2.*
from (
select
g1200,
gro