2 efrick efrick 于 2016.04.19 15:00 提问

hive配置oarcle为metastore报错ORA-01754

在hive配置远程模式metastore为Oracle,启动正常,创建表时报错

 hive> create table dht_tab(name1 int,name45 varchar(50))row format delimited fields terminated by '\t';
FAILED: Execution Error, return code 1 from org.apache.hadoop.hive.ql.exec.DDLTask. MetaException(message:javax.jdo.JDODataStoreException: An exception was thrown while adding/validating class(es) : ORA-01754: a table may contain only one column of type LONG
java.sql.SQLSyntaxErrorException: ORA-01754: a table may contain only one column of type LONG

根据网上修改"hive/lib/hive-metastore-1.2.1.jar"包中package.jdo文件,将LONGVARCHAR类型修改为CLOB,操作如下:

 cd $HIVE\_HOME/lib 
mkdir temp 
cp hive-metastore-1.2.1.jar temp 
cd temp 
jar -xvf hive-metastore-1.2.1.jar
sed -i -e 's/LONGVARCHAR/CLOB/g' package.jdo 
jar cfm hive-metastore-1.2.1.jar META-INF/MANIFEST.MF * 
cp hive-metastore-1.2.1.jar $HIVE_HOME/lib

再通过 hive --service metastore 初始化hive 再进入hive创建表仍然报相同错误。
求解????
还有一个问题 就是hive --service hiveserver2 没有反应
图片说明
感谢!

2个回答

efrick
efrick   2016.05.09 16:24
已采纳

这个问题我自己解决了 在/hive/scripts/metastore/upgrade下有各种类型的数据库的sql 如果创建不成功可直接在用sql在数据库上直接创建再运行就可以了

jenkin1016
jenkin1016   2016.04.19 15:19

这个错误是说表只能包含一个long类型的列,那最好别用long类型了

efrick
efrick 我就是把package.jdo中的long类型更换为clob 但是不知道是不生效还是什么原因,我有在网上找资料基本都是这么处理的。。请问是否还有其他方式呢
大约 2 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!
其他相关推荐
Hive学习之配置Oracle为Metastore及问题
之前学习了如何配置MySQL做为Hive的Metastore,由于在实际应用环境中统一使用的是Oracle11g,所以需要将MySQL改为Oracle。原本预料只要简单地修改hive-site.xml文件即可,却遇到了在Hive中创建表失败的问题,下面就将遇到的问题及解决方法整理一下。 首先修改hive-site.xml文件的内容如下,主要修改的地方为JDBC的URL和驱动类名。  jav
hive metastore ha 配置
1.需要在两台或多台机器上启动hive metastore 服务,这台机器上hive配置如下 javax.jdo.option.ConnectionURL jdbc:mysql://10.140.60.53:3306/hive?createDatabaseIfNotExist=true JDBC connect string for a JDBC metastor
修改hive的元数据库
修改hive的元数据库 1.  安装mysql 1.1.  通过yum来进行mysql的安装 su - root yum install -y mysql-server mysql mysql-deve 在等待了一番时间后…… 1.2.  查看mysql版本 rpm -qi mysql-server 至此我们的mysql数据库已经安装完成了。 2.  启动mysql 2
Hive学习之配置MySQL为Metastore
Hive默认情况下以内嵌模式使用Derby数据库做为metastore,该模式最大的缺陷是不支持多个客户端同时连接到metastore上,因此只适合用于学习测试的目的,要在实际生产上使用Hive需要将metastore配置为本地模式或者远程模式,现在就介绍如何以本地模式配置metastore,使用的数据库为MySQL5.6.19。在进行配置之前先要安装MySQL数据库,一般情况下Linux系统中已
Hive之——metastore三种配置方式
Hive的meta数据支持以下三种存储方式,其中两种属于本地存储,一种为远端存储。远端存储比较适合生产环境。Hive官方wiki详细介绍了这三种方式,链接为:Hive Metastore。 一、本地derby 这种方式是最简单的存储方式,只需要在hive-site.xml做如下配置便可。 javax.jdo.option.ConnectionURL jdbc:der
hive 使用oralce 存储元数据报错a table may contain only one column of type LONG
hive 使用 oracle 做元数据 建表遇到错误:a table may contain only one column of type LONG
hive配置远程metastore的方法
hive配置远程metastore的方法:     1)首先配置hive使用本地mysql存储metastore(服务器A 111.121.21.23)(也可以使用远程mysql存储)     2)配置完成后,在服务器A启动服务:/etc/init.d/hadoop-hive-metastore start  (默认监听端口是:9083)     3)配置hive客户端,修改
hive配置远程metastore
hive配置远程metastore的方法:     1)首先配置hive使用本地mysql存储metastore(服务器A 111.121.21.23)(也可以使用远程mysql存储)     2)配置完成后,在服务器A启动服务:bin/hive --service metastore  (默认监听端口是:9083)     3)配置hive客户端,修改hive-site.xml:(服务
[spark]spark/hive配置metastore为postgresql
看文档可以知道,Spark SQL复用了hive的sql解析器/metastore管理。而hive的默认的metastore为derby,它有两个弊端: 1.metastore一次仅允许一个客户端连接 2.每个客户端进行sql操作时,都会在本进程所在的文件夹内新建metastore 所以,在产品的开发中,至少应该将metastore配为postgresql的 步骤如下: 1.在pos
配置hive的常见出错总结
1. Hive metastore database is not initialized. Exception in thread "main" java.lang.RuntimeException: Hive metastore database is not initialized. Please use schematool (e.g. ./schematool -initSchem