当前位置: 代码网 > it编程>编程语言>Java > 使用MyBatis从hive中读取数据

使用MyBatis从hive中读取数据

2024年05月28日 Java 我要评论
一、hive表:启动hiveserver2二、添加mybatis starter和hive依赖<?xml version="1.0" encoding="utf-8"?><proje

一、hive表:

在这里插入图片描述

启动hiveserver2

二、添加mybatis starter和hive依赖

<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelversion>4.0.0</modelversion>

    <groupid>org.example</groupid>
    <artifactid>hivejdbc</artifactid>
    <version>1.0-snapshot</version>

    <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
    </properties>

    <parent>
        <groupid>org.springframework.boot</groupid>
        <artifactid>spring-boot-starter-parent</artifactid>
        <version>2.6.6</version>
        <relativepath/> <!-- lookup parent from repository -->
    </parent>

    <dependencies>
        <dependency>
            <groupid>org.springframework.boot</groupid>
            <artifactid>spring-boot-starter-web</artifactid>
        </dependency>

        <dependency>
            <groupid>org.mybatis.spring.boot</groupid>
            <artifactid>mybatis-spring-boot-starter</artifactid>
            <version>1.3.1</version>
        </dependency>

        <dependency>
            <groupid>org.projectlombok</groupid>
            <artifactid>lombok</artifactid>
        </dependency>
        <dependency>
            <groupid>mysql</groupid>
            <artifactid>mysql-connector-java</artifactid>
        </dependency>


        <dependency>
            <groupid>org.apache.hive</groupid>
            <artifactid>hive-jdbc</artifactid>
            <version>2.1.1</version>
            <exclusions>
                <exclusion>
                    <groupid>org.eclipse.jetty</groupid>
                    <artifactid>jetty-runner</artifactid>
                </exclusion>
            </exclusions>
        </dependency>
        <!-- https://mvnrepository.com/artifact/org.apache.hive/hive-exec -->
        <dependency>
            <groupid>org.apache.hive</groupid>
            <artifactid>hive-exec</artifactid>
            <version>3.0.0</version>
        </dependency>
        
    </dependencies>

</project>

三、配置文件application.properties中配置数据源:

server.port=9202
spring.datasource.driverclassname=org.apache.hive.jdbc.hivedriver
spring.datasource.url=jdbc:hive2://xx.xx.xx.xx:10000/default
spring.datasource.username=
spring.datasource.password=

四、定义mapper

package cn.edu.tju.mapper;

import cn.edu.tju.domain.userinfo;
import org.apache.ibatis.annotations.mapper;
import org.apache.ibatis.annotations.select;

import java.util.list;
import java.util.map;

@mapper
public interface userinfomapper {
    @select("select * from userinfo")
    list<map<string,object>> getuserlist();


}

五、定义controller,注入mapper并使用

package cn.edu.tju.controller;

import cn.edu.tju.domain.userinfo;
import cn.edu.tju.mapper.userinfomapper;
import org.springframework.beans.factory.annotation.autowired;
import org.springframework.web.bind.annotation.requestmapping;
import org.springframework.web.bind.annotation.restcontroller;

import java.util.list;
import java.util.map;

@restcontroller
public class userinfocontroller {
    @autowired
    private userinfomapper userinfomapper;

    @requestmapping("/getuserinfo")
    public string getuserinfo() {
        list<map<string, object>> userlist = userinfomapper.getuserlist();
        int size = userlist.size();
        //system.out.println(size);
        for (int i = 0; i < size; i ++ ){
            map userinfo = (map)userlist.get(i).get("userinfo");
            system.out.println(userinfo.get("x"));
            system.out.println(userinfo.get("y"));
        }

            return "ok";
    }


}

到此这篇关于使用mybatis从hive中读取数据的文章就介绍到这了,更多相关mybatis hive读取内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网! 

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com