ClickHouse 数据类型

 
查看支持的数据类型 
select * from system.data_type_families ;

select * from system.data_type_families  where case_insensitive=1;
说明: case_insensitive 为1 表示不区分大小写。case_insensitive 为0 表示严格区分大小写。

 
 
# 有符号整型(-2^n-1~2^n-1 -1):
Int8   MySQL对应类型: tinyint   数据范围:  [ -128 : 127 ]   
Int16  MySQL对应类型: smallint   数据范围:  [ -32768 : 32767 ]  
Int32  MySQL对应类型: int   数据范围: [ -2147483648 : 2147483647 ]   
Int64  MySQL对应类型: bigint   数据范围:  [ -9223372036854775808 : 9223372036854775807 ]  

# 无符号整型范围(0~2^n-1):
UInt8  MySQL对应类型: Tinyint unsigned    数据范围:  [ 0 : 255 ]
UInt16 MySQL对应类型: smallint unsigned  数据范围:  [ 0 : 65535 ]
UInt32 MySQL对应类型: Int unsigned  数据范围:  [ 0 : 4294967295 ]
UInt64 MySQL对应类型: Bigint unsigned   数据范围:  [ 0 : 18446744073709551615 ]


# 浮点型
Float32 MySQL对应类型: float   有效精度(位数):7位
Float64 MySQL对应类型: double  有效精度(位数):16位


# Decimal(定点数)
格式为:Decimal(P,S)  其中P表示精度precision,决定总位数(整数部分+小数位部分),取值范围为1--38 ,S代表规模 scale,决定小数位,取值范围是0--P。
Decimal32(S)  MySQL对应类型: Decimal(1-9,S)   数据范围:[ -1 * 10^(9 - S), 1 * 10^(9 - S) ]
Decimal64(S)  MySQL对应类型: Decimal(10-18,S) 数据范围:[ -1 * 10^(18 - S), 1 * 10^(18 - S) ]
Decimal128(S) MySQL对应类型: Decimal(19-38,S) 数据范围:[ -1 * 10^(38 - S), 1 * 10^(38 - S) ]


# 布尔型
没有单独的类型来存储布尔值。可以使用 UInt8 类型,取值限制为 0 或 1# 变长字符串 String
字符串可以任意长度的。在声明String类型的时候无须声明字符串的大小。它可以包含任意的字节集,包含空字节。


# 定长字符串 FixedString(N)
和MySQL的CHAR比较类似,对于有明确长度的字符串可以使用。和char不同的是FixedString使用Null字节填充末尾字符,而char使用空格填充。
固定长度 N 的字符串,N 必须是严格的正自然数。当服务端读取长度小于 N 的字符串时候,通过在字符串末尾添加空字节来达到 N 字节长度。 当服务端读取长度大于 N 的字符串时候,将返回错误消息。
与String相比,极少会使用FixedString,因为使用起来不是很方便。


# UUID
UUID和MySQL中的UUID类似,格式为8-4-4-4-12
若一个UUID类型的字段在写入数据时候没有被赋值则按照格式使用0填充。
localhost :) create table uuid_test(pkey UUID,name varchar ) ENGINE = Memory;
localhost :) insert into uuid_test select generateUUIDv4(),'ShangHai';
localhost :) insert into uuid_test(name) select 'GuangDong';
localhost :) select pkey,name from uuid_test;

┌─────────────────────────────────pkey─┬─name─────┐
│ 3174de9a-2b74-40e1-afeb-60c4a3adfbb6 │ ShangHai │
└──────────────────────────────────────┴──────────┘
┌─────────────────────────────────pkey─┬─name──────┐
│ 00000000-0000-0000-0000-000000000000 │ GuangDong │
└──────────────────────────────────────┴───────────┘
 

## 时间类型
时间类型最高的精确是秒,如果要处理毫秒、微秒职能借助UInt类型实现。

# DateTime
用四个字节(无符号的)存储 Unix 时间戳,允许存储与日期类型相同的范围内的值。最小值为 0000-00-00 00:00:00 
localhost :) CREATE TABLE DateTime_TEST( c1 Datetime) ENGINE=Memory;
localhost :) INSERT INTO DateTime_TEST VALUES('2020-09-27 15:48:00');
localhost :) SELECT c1,toTypeName(c1) FROM  DateTime_TEST;

┌──────────────────c1─┬─toTypeName(c1)─┐
│ 2020-09-27 15:48:00 │ DateTime       │
└─────────────────────┴────────────────┘


# DateTime64
DateTime64 可以记录亚秒,在DateTime之上增加了精度的设置。
localhost :) CREATE TABLE DateTime64_TEST( c1 Datetime64(2)) ENGINE=Memory;
localhost :) INSERT INTO DateTime64_TEST VALUES('2020-09-27 15:48:00');
localhost :) SELECT c1,toTypeName(c1) FROM  DateTime64_TEST;

┌─────────────────────c1─┬─toTypeName(c1)─┐
│ 2020-09-27 15:48:00.00 │ DateTime64(2)  │
└────────────────────────┴────────────────┘


# Date
Date类型不包含具体的时间信息,只精确到天。
localhost :) CREATE TABLE my_Date_TEST( c1 Date) ENGINE=Memory;
localhost :) INSERT INTO my_Date_TEST VALUES('2020-09-27');
localhost :) SELECT c1,toTypeName(c1) FROM  my_Date_TEST;

┌─────────c1─┬─toTypeName(c1)─┐
│ 2020-09-27 │ Date           │
└────────────┴────────────────┘



# 枚举类型
枚举类型包括Enum8和Enum16两种,这两者只有取值范围不同的差别。
Enum8 用 'String'= Int8 对描述。
Enum16 用 'String'= Int16 对描述。

Enum 保存 'string'= integer 的对应关系。在 ClickHouse 中,尽管用户使用的是字符串常量,但所有含有 Enum 数据类型的操作都是按照包含整数的值来执行。这在性能方面比使用 String 数据类型更有效。
举例:新建一张带Enum8类型的表:
localhost :) CREATE TABLE  enum_t (  et Enum8('a' = 1, 'b' = 2, 'c' =3)) ENGINE = TinyLog;
localhost :) DESC enum_t ;
┌─name─┬─type─────────────────────────────┬─default_type─┬─default_expression─┬─comment─┬─codec_expression─┬─ttl_expression─┐
│ et   │ Enum8('a' = 1, 'b' = 2, 'c' = 3) │              │                    │         │                  │                │
└──────┴──────────────────────────────────┴──────────────┴────────────────────┴─────────┴──────────────────┴────────────────┘

插入数据
localhost :) INSERT INTO enum_t(et) VALUES ('a'),('a'),('b');

查看
localhost :) SELECT * FROM enum_t ;
┌─et─┐
│ a  │
│ a  │
│ b  │
└────┘


如果需要看到对应行的数值,则必须将 Enum 值转换为整数类型:
localhost :) SELECT CAST(et, 'Int8') FROM enum_t ;
┌─CAST(et, 'Int8')─┐
│                1 │
│                1 │
│                2 │
└──────────────────┘


# 数据类型
Array(T)
    
由 T 类型元素组成的数组。T 可以是任意类型,包含数组类型,但不推荐使用多维数组,ClickHouse 对多维数组的支持有限。
可以使用array()函数和中括号来创建数组

举例:
新建两张带Array类型的表:
localhost :) CREATE TABLE array_t (arr Array(UInt8)) ENGINE = TinyLog;
localhost :) CREATE TABLE array_ta (arr Array(String)) ENGINE = TinyLog;

插入数组
localhost :) INSERT INTO array_t VALUES([1,2,3,4,5]),(array(11,22,33,44,55));
localhost :) INSERT INTO array_ta VALUES(['a','b','c']),(array('x','y','z','123'));

查看结果
localhost :) SELECT * FROM array_t ;
┌─arr──────────────┐
│ [1,2,3,4,5]      │
│ [11,22,33,44,55] │
└──────────────────┘

localhost :) SELECT * FROM array_ta;
┌─arr─────────────────┐
│ ['a','b','c']       │
│ ['x','y','z','123'] │
└─────────────────────┘



# 元组类型
Tuple(T1, T2, ...)

元组,其中每个元素都有单独的类型。
创建一张带tuple字段的表:
localhost :) CREATE TABLE tuple_t (ttt Tuple(Int8, String, Array(String), Array(Int8))) ENGINE = TinyLog;

插入数据
localhost :) INSERT INTO tuple_t VALUES((1, 'a', ['a', 'b', 'c'], [1, 2, 3])),(tuple(11, 'A', ['A', 'B', 'C'], [11, 22, 33]));

查看数据
localhost :) SELECT * FROM tuple_t ;
┌─ttt───────────────────────────────┐
│ (1,'a',['a','b','c'],[1,2,3])     │
│ (11,'A',['A','B','C'],[11,22,33]) │
└───────────────────────────────────┘





  

 

posted @ 2020-09-28 10:51  屠魔的少年  阅读(42)  评论(0)    收藏  举报