您好,欢迎访问一九零五行业门户网

Hive-sql和sql的区别是什么?

区别:1、hive-sql不支持等值连接,而sql支持;2、hive-sql不支持“insert into 表 values()”、updata、delete操作,而sql支持;3、hive-sql不支持事务,而sql支持。
总体来说hivesql与sql基本上一致,最初的设计目的就是为了让会sql但是不会编程mapreduce的人也能使用hadoop进行数据处理。
1、hive不支持等值连接
不支持等值连接,一般使用left join、right join 或者inner join替代。
例如:
sql中内关联可以这样写: select * from a , b where a.key = b.key
hive中应该这样写: select * from a join b on a.key = b.key
hive中不能使用省去join的写法。
2、分号字符
分号是sql语句的结束符号,在hive中也是,但是hive对分号的识别没有那么智能,有时需要进行转义 “;” --> “\073”
3、null
sql中null代表空值,但是在hive中,string类型的字段若是空(empty)字符串,即长度为0,那么对它 is null 判断结果为false
4、hive不支持将数据插入现有的表或分区中
hive仅支持覆盖重写整个表。
insert overwrite 表 (重写覆盖)
5、hive不支持 insert into 表 values(), updata , delete 操作
insert into 就是往表或者分区中追加数据。
6、hive支持嵌入mapreduce程序,来处理复杂的逻辑
暂时没有例子可以提供。
7、hive支持将转换后的数据直接写入不同的表,还能写入分区,hdfs和本地目录
避免多次扫描输入表的开销。
8、hql不支持行级别的增、改、删,所有数据在加载时就已经确定,不可更改。
更多编程相关知识,请访问:编程入门!!
以上就是hive-sql和sql的区别是什么?的详细内容。
其它类似信息

推荐信息