日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

hive map格式转换为字符串_Hive与MySQL的不同之处之类型转换cast和covert函数

發(fā)布時(shí)間:2025/3/11 数据库 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 hive map格式转换为字符串_Hive与MySQL的不同之处之类型转换cast和covert函数 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

Hive:

cast(xxx AS 類(lèi)型)

如:

cast(tm AS bigint)

附上Hive基本數(shù)據(jù)類(lèi)型:

數(shù)據(jù)類(lèi)型

所占字節(jié)

開(kāi)始支持版本

TINYINT

1byte,-128 ~ 127

SMALLINT

2byte,-32,768 ~ 32,767

INT

4byte,-2,147,483,648 ~ 2,147,483,647

BIGINT

8byte,-9,223,372,036,854,775,808 ~ 9,223,372,036,854,775,807

BOOLEAN

FLOAT

4byte單精度

DOUBLE

8byte雙精度

STRING

BINARY

從Hive0.8.0開(kāi)始支持

TIMESTAMP

從Hive0.8.0開(kāi)始支持

DECIMAL

從Hive0.11.0開(kāi)始支持

CHAR

從Hive0.13.0開(kāi)始支持

VARCHAR

從Hive0.12.0開(kāi)始支持

DATE

從Hive0.12.0開(kāi)始支持

復(fù)雜類(lèi)型包括ARRAY,MAP,STRUCT,UNION,這些復(fù)雜類(lèi)型是由基礎(chǔ)類(lèi)型組成的。

ARRAY

ARRAY類(lèi)型是由一系列相同數(shù)據(jù)類(lèi)型的元素組成,這些元素可以通過(guò)下標(biāo)來(lái)訪問(wèn)。比如有一個(gè)ARRAY類(lèi)型的變量fruits,它是由[‘a(chǎn)pple’,’orange’,’mango’]組成,那么我們可以通過(guò)fruits[1]來(lái)訪問(wèn)元素orange,因?yàn)锳RRAY類(lèi)型的下標(biāo)是從0開(kāi)始的;

MAP:

MAP包含key->value鍵值對(duì),可以通過(guò)key來(lái)訪問(wèn)元素。比如”userlist”是一個(gè)map類(lèi)型,其中username是key,password是value;那么我們可以通過(guò)userlist[‘username’]來(lái)得到這個(gè)用戶對(duì)應(yīng)的password;

STRUCT:

STRUCT可以包含不同數(shù)據(jù)類(lèi)型的元素。這些元素可以通過(guò)”點(diǎn)語(yǔ)法”的方式來(lái)得到所需要的元素,比如user是一個(gè)STRUCT類(lèi)型,那么可以通過(guò)user.address得到這個(gè)用戶的地址。

UNION:

UNION TYPE,他是從Hive 0.7.0開(kāi)始支持的。

創(chuàng)建一個(gè)包含復(fù)制類(lèi)型的表格可以如下

CREATE TABLE employees (

name STRING,

salary FLOAT,

subordinates ARRAY,

deductions MAP,

address STRUCT

) PARTITIONED BY (country STRING, state STRING);

MySQL:

cast(xxx AS 類(lèi)型)或convert(xxx,類(lèi)型),類(lèi)型必須用下列的類(lèi)型:

二進(jìn)制,同帶binary前綴的效果 : BINARY

字符型,可帶參數(shù) : CHAR()

日期 : DATE

時(shí)間: TIME

日期時(shí)間型 : DATETIME

浮點(diǎn)數(shù) : DECIMAL

整數(shù) : SIGNED

無(wú)符號(hào)整數(shù) : UNSIGNED

如:cast(tm AS signed)

或convert(tm,signed)

警告:

MySQL類(lèi)型轉(zhuǎn)換不能用int之類(lèi)的,否則會(huì)報(bào)錯(cuò):

cast(tm AS int)

或convert(tm,int)

附上MySQL基本數(shù)據(jù)類(lèi)型:

|** 類(lèi)型 **| **大小 **| ** 描述 **|

|————| ———-| ———- |:———–:|

|char[length] | length字節(jié) | 定長(zhǎng)字段,長(zhǎng)度為0-255個(gè)字節(jié)|

|varchar[length] | string長(zhǎng)度+1字節(jié) | 變長(zhǎng)字段,在mysql5.03以前,長(zhǎng)度為0-255個(gè)字節(jié),在5.0.3以后,最大長(zhǎng)度為65535字節(jié)。一個(gè)utf8字符占3個(gè)字節(jié)、一個(gè)gbk字符占兩個(gè)字節(jié)。|

|tinytext | string長(zhǎng)度+1字節(jié) | 字符串,長(zhǎng)度為0-255個(gè)字節(jié)|

|text | string長(zhǎng)度+2字節(jié) | 字符串,最大長(zhǎng)度為0-65535個(gè)字節(jié)|

|mediumtext | string長(zhǎng)度+3字節(jié) | 字符串,最大長(zhǎng)度為16777215個(gè)字節(jié)|

|longtext | string長(zhǎng)度+4字節(jié) | 字符串,最大長(zhǎng)度為4194967295個(gè)字節(jié)|

|tinyint[length] | 1字節(jié) | 范圍:-128127或0255|

|smallint[length] | 2字節(jié) | |

|mediumint[length] | 3字節(jié) | |

|int[length] | 4字節(jié) | |

|bigint[length] | 8字節(jié) | |

|float | 4字節(jié) | |

|double[length,decimals] | 8字節(jié) | 運(yùn)行固定的小數(shù)點(diǎn)|

|decimal[length,decimals] | length+1字節(jié)或length+2字節(jié) | |

|date | 3字節(jié) | 采用YYYY-MM-DD格式|

|datetime | 8字節(jié) | 采用YYYY-MM-DD HH:mm:SS格式|

|timestamp | 4字節(jié) | 采用YYYYMMDDHHmmSS格式|

|time | 3字節(jié) | 采用HH:MM:SS格式|

|enum | 1或2字節(jié) | 枚舉類(lèi)型|

|set | 1、2、3、4或8字節(jié) | 與enum一樣,只不過(guò)每一列可以具有多個(gè)可能的值|

|blob | | 是text的一個(gè)變體。允許存儲(chǔ)二進(jìn)制文件,還可用于某些加密數(shù)據(jù)。|

總結(jié)

以上是生活随笔為你收集整理的hive map格式转换为字符串_Hive与MySQL的不同之处之类型转换cast和covert函数的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。