由于hive3客户端版本只需要一个jdbc即可,datagrip在连接hive时只会显示3.x.x版本以上的驱动。使用2.x.x版本时很多不兼容,故而需要自己去设置客户端jar包驱动。
首先,创建一个新的maven项目,引入对应hive的jdbc。我这里是2.1.1,根据自己需求来
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.example</groupId>
<artifactId>demo4jar</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>demo4jar</name>
<description>demo4jar</description>
<properties>
<java.version>8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.apache.hive</groupId>
<artifactId>hive-jdbc</artifactId>
<version>2.1.1</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<executions>
<execution>
<id>copy-dependencies</id>
<phase>prepare-package</phase>
<goals>
<goal>copy-dependencies</goal>
</goals>
<configuration>
<outputDirectory>${project.build.directory}/lib</outputDirectory>
<overWriteReleases>false</overWriteReleases>
<overWriteSnapshots>false</overWriteSnapshots>
<overWriteIfNewer>true</overWriteIfNewer>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
</project>
因为加入了插件将所有hive-jdbc依赖都打入target目录下的lib文件夹下。
然后将依赖加入到DataGrip中,全选打包的lib目录下所有文件即可。
最后测试连接: