Hive/MySql 踩坑

本文探讨了在使用Hive时配置元数据存储在MySQL中以解决多连接问题的方法,同时对比了Hive与MySQL在处理复杂查询时的语法差异,如部门薪资排名查询的实现方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  • 在使用hive 需要配置元数据存储在mysql中,来解决不能多连接的问题
    数据库的名称
    1)不能含有" . "
    2)不要以数字开始
  • mysql中SQL语句与hive存在不同
    比如经典员工部门问题:求部门薪资前几的人员信息
    在MySQL中:
select dept.dname ,emp1.job ,emp1.sal
from db_hive.tb_dept dept join db_hive.tb_emp emp1
on dept.deptno=emp1.deptno
where(
    select count(emp2.sal) as c_sal 
	from db_hive.tb_emp emp2 
	where 
		emp2.sal>emp1.sal and emp2.deptno=emp1.deptno and emp2.job =emp1.job
	)<n
order by emp1.deptno,emp1.sal desc

在hive中就会报错:
FAILED: ParseException line 4:6 cannot recognize input near ‘select’ ‘count’ ‘(’ in expression specification

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值