AWSAthena:如何处理GetQueryResultsCommand命令返回的数据?
创始人
2024-09-23 21:30:59
0

AWS SDK for Java 2.0提供了适用于Athena的客户端库。以下是使用AthenaClient执行查询并处理返回结果的示例:

import software.amazon.awssdk.auth.credentials.DefaultCredentialsProvider;
import software.amazon.awssdk.regions.Region;
import software.amazon.awssdk.services.athena.AthenaClient;
import software.amazon.awssdk.services.athena.model.*;

import java.util.List;
import java.util.concurrent.ExecutionException;

public class AthenaQueryExample {

    private static final String ATHENA_DB = "your-database-name";
    private static final String ATHENA_OUTPUT_BUCKET = "s3://your-bucket-name/your-folder-name/";
    private static final String ATHENA_QUERY_STRING = "SELECT count(*) FROM your-table-name WHERE your-column-name = 'your-value'";

    public static void main(String[] args) {
        // create Athena client
        AthenaClient athenaClient = AthenaClient.builder()
                .credentialsProvider(DefaultCredentialsProvider.create())
                .region(Region.US_WEST_2)
                .build();

        // setup query execution request
        StartQueryExecutionRequest startQueryExecutionRequest = StartQueryExecutionRequest.builder()
                .queryString(ATHENA_QUERY_STRING)
                .queryExecutionContext(QueryExecutionContext.builder().database(ATHENA_DB).build())
                .resultConfiguration(ResultConfiguration.builder().outputLocation(ATHENA_OUTPUT_BUCKET).build())
                .build();

        // execute query and get query execution ID
        String queryExecutionId = athenaClient.startQueryExecution(startQueryExecutionRequest).queryExecutionId();

        // setup query results request
        GetQueryResultsRequest getQueryResultsRequest = GetQueryResultsRequest.builder()
                .queryExecutionId(queryExecutionId)
                .build();

        // poll query status until query completes
        boolean isQueryStillRunning = true;
        while (isQueryStillRunning) {
            GetQueryExecutionRequest getQueryExecutionRequest = GetQueryExecutionRequest.builder().queryExecutionId(queryExecutionId).build();
            QueryExecution queryExecution = athenaClient.getQueryExecution(getQueryExecutionRequest).queryExecution();
            String queryState = queryExecution.status().state();

            if (queryState.equals(QueryExecutionState.FAILED.toString())) {
                throw new RuntimeException("Athena

相关内容

热门资讯

8分钟带你解说!吉祥填大坑有什... 8分钟带你解说!吉祥填大坑有什么诀窍(辅助挂)果然真的是有挂(有挂秘诀)-哔哩哔哩;小薇(透视辅助)...
第八分钟带你普及!战神辅助官网... 第八分钟带你普及!战神辅助官网(辅助挂)一直是有挂的(有挂规律)-哔哩哔哩;1、完成战神辅助官网的残...
第七分钟带你科普!微信黑科技辅... 第七分钟带你科普!微信黑科技辅助神器(辅助挂)其实真的有挂(确实有挂)-哔哩哔哩;详细微信黑科技辅助...
第4分钟带你开挂!家乡大贰智能... 第4分钟带你开挂!家乡大贰智能辅助(辅助挂)一直真的是有挂(有人有挂)-哔哩哔哩;1、让任何用户在无...
第4分钟带你透视!微信蜀山四川... 第4分钟带你透视!微信蜀山四川修改器先测试(辅助挂)其实真的是有挂(新版有挂)-哔哩哔哩;是一款可以...
三分钟带你了解!来物局潮汕麻雀... 三分钟带你了解!来物局潮汕麻雀(辅助挂)其实真的是有挂(有挂细节)-哔哩哔哩;亲真的是有正版授权,小...
热点推荐"白银胡乐辅... 热点推荐"白银胡乐辅助最简单三个步骤"开挂(透视)辅助平台(其实真的有挂的)-哔哩哔哩;人气非常高,...
1分钟带你得知!哥哥打大a辅助... 1分钟带你得知!哥哥打大a辅助神器(辅助挂)原来真的是有挂(有挂总结)-哔哩哔哩;1.哥哥打大a辅助...
一分钟揭秘"四川途游... 一分钟揭秘"四川途游辅助软件下载"开挂(透视)辅助安装(一直确实是有挂)-哔哩哔哩;相信小伙伴都知道...
十分钟带你介绍!四川麻将口诀顺... 十分钟带你介绍!四川麻将口诀顺口溜(辅助挂)果然真的有挂(有挂方式)-哔哩哔哩;1.四川麻将口诀顺口...