11

如何在 Hive 中实现与 SQL 的“偏移量”相同的功能?

SELECT * from table LIMIT 20 OFFSET 30

谢谢!

4

3 回答 3

15

我不知道会模仿这种行为的内置函数或 UDF,但如果你正在使用HIVE 0.13,你可以row_number()以一种迂回的方式使用该函数来获得所需的结果。

select pk, col_1, col_2, ... , col_n
from (
    select pk, col_1, col_2, ... , col_n, row_number() OVER (ORDER by pk) as rank
    from some_database.some_table
    ) x
where rank between 31 and 50
于 2014-09-12T02:35:13.073 回答
1

限制适用于 2 个参数。限制(计数)和限制偏移量,计数。

所以请使用第二个选项。和

select salary from employee order by salary desc limit 0,1

你会得到最高的薪水。

这里(偏移)0 - 第一行和计数 (1)

于 2020-01-27T13:53:25.120 回答
0
public class CountRatingQueryBuilder {

private static final String SCORING_TABLE_NAME = "web_resource_rating";

private final Connection connection;
private final ScoringMetadata scoringMetadata;

private final SelectSelectStep select;
private final Factory create;

public CountRatingQueryBuilder(Connection connection, ScoringMetadata scoringMetadata){
    this.connection = connection;
    this.scoringMetadata = scoringMetadata;

    create = new Factory(this.connection, SQLDialect.MYSQL);
    select = create.select();

    withSelectFieldsClause();
}

public CountRatingQueryBuilder withLimit(int limit){
    select.limit(limit);
    return this;
}

public CountRatingQueryBuilder withRegionId(Integer regionId){
    select.where(REGION_ID.field().equal(regionId));
    return this;
}

public CountRatingQueryBuilder withResourceTypeId(int resourceTypeId){
    select.where(RESOURCE_TYPE_ID.field().equal(resourceTypeId));
    return this;
}

public CountRatingQueryBuilder withRequestTimeBetween(long beginTimestamp, long endTimestamp){
    select.where(REQUEST_TIME.field().between(beginTimestamp, endTimestamp));
    return this;
}

public CountRatingQueryBuilder withResourceId(int resourceId){
    select.where(RESOURCE_ID.field().equal(resourceId));
    return this;
}



protected void withGroupByClause(){
    select.groupBy(REGION_ID.field());
    select.groupBy(RESOURCE_TYPE_ID.field());
    select.groupBy(RESOURCE_ID.field());
    select.groupBy(CONTENT_ID.field());
}

protected void withSelectFieldsClause(){
    select.select(REGION_ID.field());
    select.select(RESOURCE_TYPE_ID.field());
    select.select(CONTENT_ID.field());
    select.select(RESOURCE_ID.field());
    select.select(Factory.count(HIT_COUNT.field()).as(SUM_HIT_COUNT.fieldName()));
}

protected void withFromClause(){
    select.from(SCORING_TABLE_NAME);
}

protected void withOrderByClause(){
    select.orderBy(SUM_HIT_COUNT.field().desc());
}

public String build(){
    withGroupByClause();
    withOrderByClause();
    withFromClause();
    return select.getSQL().replace("offset ?","");//dirty hack for MySQL dialect. TODO: we can try to implement our own SQL dialect for Hive :)

}

public List<ResultRow> buildAndFetch(){
    String sqlWithPlaceholders = build();

    List<ResultRow> scoringResults = new ArrayList<ResultRow>(100);
    List<Record> recordResults = create.fetch(sqlWithPlaceholders, ArrayUtils.subarray(select.getBindValues().toArray(new Object[select.getBindValues().size()]),0, select.getBindValues().size()-1));//select.fetch();
    for(Record record : recordResults){
        ResultRowBuilder resultRowBuilder = ResultRowBuilder.create();

        resultRowBuilder.withContentType(scoringMetadata.getResourceType(record.getValue(RESOURCE_TYPE_ID.fieldName(), Integer.class)));
        resultRowBuilder.withHitCount(record.getValue(SUM_HIT_COUNT.fieldName(), Long.class));
        resultRowBuilder.withUrl(record.getValue(CONTENT_ID.fieldName(), String.class));
        scoringResults.add(resultRowBuilder.build());
    }
    return scoringResults;
}

}

希望这是从以下链接复制的正确答案:请参考jooq 扩展现有方言。采用 MySQL dialect to apache Hive dialect详细了解这个。

于 2014-09-18T11:15:08.713 回答