hive面试--hive与常见数据库区别以及hive的数据类型

一、hive与常见数据库的区别
hive是数据仓库的基础工具,能够将结构化的数据映射为一张张表从而进行sql操作。

  1. 数据存储位置
    hive是建立在hadoop的基础之上的,所有hive的数据都是存储在hdfs上;而数据库则可以将数据保存在块设备或者本地文件系统中

  2. 数据更新
    由于hive是针对数据仓库进行设计的,而数据仓库主要是进行数据分析,即读多写少,所以hive中是不建议对数据进行改写,所有的数据在加载的时候就已经确定了;而数据库中的数据通常是要进行修改的,即进行inerst into … values添加数据和update…set修改语句
    默认情况下,hive是不支持行级更新和删除。如果要进行行级操作,需要修改hive的配置参数让hive支持事务操作。

  3. 数据执行
    hive的执行引擎是mapReduce,并且hive没有索引,所以在hive的查询会有较高的延迟,相对而言,数据库的执行延迟会比较低。当然这个比较低也是在数据量比较小的条件下,当数据规模大到超出数据库的执行能力的时候,hive的并行计算能力就体现出来了。

  4. 可扩展性
    hive是建立在hadoop上,所以hive和hadoop一样具有良好的扩展性;而数据库由于ACID语义的严格限制,扩展性非常有限
    ACID即关系型数据库的事务的四大特征:
    A(Atomicity)原子性:事务的所有操作要么全部成功要么全部失败
    C(Consistency)一致性:数据库要一直处于一致的状态,事务的运行不会改变数据库原本的一致性约束。比如 现在完整性约束a+b=10,如果一个事务改变了a,那么必须改变b,使得事务结束后依然满足a+b=10,否则事务失败。
    I(Isolation)独立性:并发的事务之间不会互相影响,如果一个事务要访问的数据正在被另外一个事务修改,只要另外一个事务未提交,它所访问的数据就不会受未提交事务的影响。
    D(Durability)持久性:一旦事务提交之后,它所做的修改将会永久的保存在数据库上,即使出现宕机也不会丢失。

二、hive的数据类型

  1. 基本数据类型
    在这里插入图片描述
    hive中string和数据库中varchar类型基本一致,不过hive中的string不能声明字段的长度

  2. 集合数类型
    在这里插入图片描述
    三、hive底层如何存储null值
    int和string类型的数据,hive存储null值默认都是 ‘\N’,如果int类型字段插入’ ',那么hive底层是当作null值按照 '\N’存储,如果String类型字段插入" “,那么hive底层是当作” "来存储。对于int类型的数据用 is null来判断null值,对于String类型的数据,用 is null来判断null值,用 = " "来判断空值。

### IntelliJ IDEA 2025 安装教程 #### 准备工作 为了确保顺利安装 IntelliJ IDEA 2025 版本,在开始之前需确认操作系统环境已准备好。对于 Windows 用户来说,建议先检查系统是否满足最低硬件需求以及是否有足够的磁盘空间[^1]。 #### 下载 IntelliJ IDEA 2025 访问官方网站 [IntelliJ IDEA – the Leading Java and Kotlin IDE](https://www.jetbrains.com/idea/) ,找到对应于 2025 年发布的最新版链接并点击下载适合当前操作系统的安装包文件。通常页面会自动检测用户的平台类型提供相应的选项;如果未自动识别,则手动选择合适的版本进行下载[^2]。 #### 执行安装程序 双击刚刚下载好的 `.exe` 文件启动安装向导。按照提示逐步完成设置过程,期间可以选择自定义组件或接受默认推荐配置。值得注意的是,在此阶段还可以指定产品密钥以激活专业特性,不过社区版无需额外授权即可免费使用全部基础功能。 #### 配置 JDK 环境(可选) 虽然不是强制性的前置条件,但如果计划从事 Java 开发项目的话,提前安装好适当版本的 JDK 是很有必要的。可以通过官方渠道获取最新的 JDK 发行版,并将其路径添加到系统的环境变量中以便后续集成开发环境中能够正确调用编译工具链。 #### 启动初始化 成功安装完毕之后,通过桌面快捷方式打开应用程序。首次运行时可能会经历一段短暂的数据加载时间用于构建索引库和其他准备工作。此时可以根据个人喜好调整界面布局、主题样式等外观属性,同时也可以探索插件市场寻找有助于提高工作效率的各种扩展模块。 ```bash # 如果遇到任何问题可以尝试重启IDE解决问题 ./idea.sh restart ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值