阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

infobright数据仓库中的comment lookup

200次阅读
没有评论

共计 1254 个字符,预计需要花费 4 分钟才能阅读完成。

infobright 数据仓库能在高强度的压缩中把大量的数据压缩存储,平时在不断查询的过程就是在做数据解压的过程,当然具体的详细介绍在以前有提过,这里就不做过程的介绍(http://www.linuxidc.com/Linux/2017-10/147939.htm)在 infobright 中支持所有的 MySQL 原有的数据类型,其中对整形的效率会比其他类型高,这一点同 MySQL 差不多,在 infobright 中比较高效的类型如下:

1、TINYINT,SMALLINT,MEDIUMINT,INT,BIGINT
2、DECIMAL(尽量减少小数点后的精度)
3、DATE,TIME

这 3 种类型的数据能有比较高的压缩比例及查询速度,而效率比较低的、不推荐使用的数据类型有这几种:

1、BINARY VARBINARY(二进制类型)
2、FLOAT
3、DOUBLE
4、VARCHAR
5、TINYTEXT TEXT(可变长度的非 Unicode 类型)

这些数据类型在使用的过程中效率比较低且压缩比例并不是很高,其中 VARCHAR 字段在 MySQL 中效率就不如 CHAR 字段,当然在某些业务场景下可能会不得不用到 CHAR(VARCHAR)的时候又经常需要频繁的查询时,但数据的记录数又并不是很多时(不多于 10000 行,且数据的类型多于 10 种以上,类似于省份、UUID 这类的数据),就可以通过 comment lookup 的方式创建建表时的 DDL 来提高平时查询的效率如下:

# 原建表 DDL

CREATE TABLE `test_default` (

  `dstphone` varchar(11) DEFAULT NULL,

  `gateid` varchar(255) DEFAULT NULL

) ENGINE=BRIGHTHOUSE DEFAULT CHARSET=utf8;

#comment lookup 建表 DDL

CREATE TABLE `test_lookup` (

  `dstphone` varchar(11) DEFAULT NULL COMMENT ‘lookup’,

  `gateid` varchar(255) DEFAULT NULL COMMENT ‘lookup’

) ENGINE=BRIGHTHOUSE DEFAULT CHARSET=utf8;

这里需要注意的是 comment lookup 的方式目前仅有在 CHAR(VARCHAR)中能使用,其次在平时带来更高的查询效率所带来的代价就是磁盘开销,因为 infobright 在平时查询的时候就是在做解压的过程,所以使用 comment lookup 的方式就是降低压缩比例,在查询的时候能更快速的解压数据,如下可以看出 comment lookup 的方式同默认的建表时不同的压缩比例

infobright 数据仓库中的 comment lookup

infobright 数据仓库中的 comment lookup

查询效率如下:

infobright 数据仓库中的 comment lookup

infobright 数据仓库中的 comment lookup

可以看相同的数据下所占用磁盘空间,但相应的在查询记录不能超过 10000 行,不然反而还会降低其效率:

infobright 数据仓库中的 comment lookup

infobright 数据仓库中的 comment lookup

所以在使用的过程中还需要根据实际情况来选择。

本文永久更新链接地址 :http://www.linuxidc.com/Linux/2018-01/150650.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计1254字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中