Hive之殇

15 篇文章 0 订阅
2 篇文章 0 订阅

问题1:java.lang.NoSuchMethodError:javax.persistence.PersistenceContext.synchronization()Ljavax/persistence/SynchronizationType;
猜想:
这个问题很有可能是组织jar包的错误,错误的组织jar包导致PersistenceContext有重复导致程序不能工作。
解决方案:
在eclipse中使用ctrl+shift+T打开类型管理器输入PersistenceContext类型,然后可以看到和这个名称同名的所有类都会被显示出来(下图是我已经调好的,如果有问题会看到很多同名的类)。
在这里插入图片描述
将所有同名的类所在的jar包删掉,我这边原来同名的有Tomcat中annotations-api.jar和persistence-api-1.0.2.jar包,删除这些包然后重新运行程序就可以了
在这里插入图片描述
删除方法:
Tomcat:它的包直接到安装路径lib目录下删除annotations-api.jar就可以了
maven:到pom文件把persistence-api的依赖注掉或者直接删掉更新maven就可以了
问题2:
问题描述:hive导入数据成功,但是查询结果为NULL,且未报错
在这里插入图片描述
解决方案:这是因为创建表格时没有对导入的数据格式没有处理,比如每行数据以tab键隔开,以换行键结尾,就要以如下语句创建表格:

create table if not exists employee(eid int,name String, salary String,
          destination String) ROW FORMAT DELIMITED FIELDS TERMINATED BY ' \t' LINES TERMINATED BY '\n' STORED AS TEXTFILE;

而不是简单的创建表格。
数据:
在这里插入图片描述
然后再执行导入就可以了

load data local inpath '/opt/bigdata/data/sample.txt' overwrite into table employee;

在这里插入图片描述
这样就正常了!
问题3:
问题描述:springboot-jpa(利用hibernate实现)连接Hive报错。
解决方案:
网上说官方不支持,连接mysql没问题,连接hive就有问题,然后我发现属性配置文件按照如下方式编写就可以成功了。

################### server\u914d\u7f6e #####################
server.port=8071
#session\u8d85\u65f6\u65f6\u95f4
server.servlet.session.timeout=3000
##service \u6ce8\u518c\u670d\u52a1\u4e2d\u5fc3
#spring.application.name=base
#\u662f\u5426\u5411\u670d\u52a1\u6ce8\u518c\u4e2d\u5fc3\u6ce8\u518c\u81ea\u5df1
eureka.client.register-with-eureka=false
#\u662f\u5426\u68c0\u7d22\u670d\u52a1
eureka.client.fetch-registry=false
#eureka.client.service-url.defaultZone=http://localhost:8671/eureka/
################### server\u914d\u7f6e\u7ed3\u675f #####################

###################### \u6570\u636e\u5e93\u8fde\u63a5\u914d\u7f6e #########################
#spring.datasource.driver-class-name=com.mysql.jdbc.Driver
#spring.datasource.url=jdbc:mysql://localhost:3306/cssbase1?charset=utf8mb4&serverTimezone=UTC
#spring.datasource.username=root
#spring.datasource.password=801002

#spring.datasource.hadoop.type=org.apache.tomcat.jdbc.pool.DataSource
#spring.datasource.hadoop.url=jdbc:hive2://192.168.225.100:10000/default
#spring.datasource.hadoop.username=hive
#spring.datasource.hadoop.password=123456
#spring.datasource.hadoop.driver-class-name = org.apache.hive.jdbc.HiveDriver

spring.datasource.driver-class-name=org.apache.hive.jdbc.HiveDriver
spring.datasource.url=jdbc:hive2://192.168.225.100:10000/default
spring.datasource.username=hive
spring.datasource.password=123456
###################### \u6570\u636e\u5e93\u8fde\u63a5\u914d\u7f6e\u7ed3\u675f #######################

####################### JPA\u914d\u7f6e ##########################
#spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.MySQL5InnoDBDialect
#spring.jpa.properties.hibernate.hbm2ddl.auto=update
#spring.jpa.show-sql=true
#这里是重点
spring.jpa.database-platform=org.hibernate.dialect.HSQLDialect
spring.jpa.generate-ddl=false
spring.jpa.show-sql=true
spring.jpa.database=HSQL

###################### JPA\u914d\u7f6e\u7ed3\u675f ########################

问题3:
Error occured while trying to connect to the database

Error connecting to database: (using class org.hsqldb.jdbcDriver)
Unable to load Hive Server 2 JDBC driver for the currently active Hadoop configuration

org.pentaho.di.core.exception.KettleDatabaseException:
Error occured while trying to connect to the database

Error connecting to database: (using class org.hsqldb.jdbcDriver)
Unable to load Hive Server 2 JDBC driver for the currently active Hadoop configuration

at org.pentaho.di.core.database.Database.normalConnect(Database.java:415)
at org.pentaho.di.core.database.Database.connect(Database.java:353)
at org.pentaho.di.core.database.Database.connect(Database.java:306)

未完待续…

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值