大数据学习之hive的jdbc测试类编写

本文介绍了Hive中JDBC测试命令的编写步骤。首先加载Hive驱动,接着建立与数据的连接,然后引入接口,最后编写类似SQL的HQL语句,使用接口封装的execute和executeQuery方法分别进行添加和查询操作。

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

JDBC编写步骤

JDBCTest.java
import java.sql.*;    
public class JdbcTest {
public static void main(String[] args) throws SQLException {
    try {

1.加载驱动 (这里连接的是hive:org.apache.hive.jdbc.HiveDriver)

        Class.forName("org.apache.hive.jdbc.HiveDriver");
    } catch (ClassNotFoundException e) {
        e.printStackTrace();
        System.exit(1);
    }

2.建立连接 (与数据建立链接:“jdbc:hive2://192.168.230.131:10000/test”,“root”,“root”)

    //通信端口 :50070 9000 50090 8080 8088 3306 22 2181 2888/3888 10000
    Connection con = DriverManager.getConnection("jdbc:hive2://192.168.230.131:10000/test","root","root");

3.引入接口

Statement sta = con.createStatement();

4.编写hql语句(类似于sql)用接口封装的excute 和 executeQuery方法分别进行添加和查询操作

    String tableName = "jdbcTest2";
    sta.execute("drop table if exists"+tableName);
    sta.execute("CREATE table "+tableName+"(key int,value String)");
    System.out.println("Create table success!");

    //show tables
    String sql = "show tables '"+tableName+"'";
    System.out.println("Running: "+sql);
    ResultSet res = sta.executeQuery(sql);
    if(res.next()){
        System.out.println(res.getString(1));
    }

    //describe table
    sql = "describe "+tableName;
    System.out.println("Running: "+sql);
    res = sta.executeQuery(sql);
    while(res.next()){
        System.out.println(res.getString(1)+"\t"+res.getString(2));
    }

    sql ="select * from "+tableName;
    res = sta.executeQuery(sql);
    while(res.next()){
        System.out.println(String.valueOf(res.getInt(1)+"\t"+res.getString(2)));
    }

    sql = "select count(1) from "+tableName;
    System.out.println("Running: "+sql);
    res = sta.executeQuery(sql);
    while(res.next()){
        System.out.println(res.getString(1));
    }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值