IteratorReducerResultSet.java 2.1 KB
Newer Older
G
gaohongtao 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
/**
 * Copyright 1999-2015 dangdang.com.
 * <p>
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * </p>
 */

package com.dangdang.ddframe.rdb.sharding.merger.component.reducer;

import com.dangdang.ddframe.rdb.sharding.jdbc.adapter.AbstractResultSetAdapter;
import com.dangdang.ddframe.rdb.sharding.merger.component.ReducerResultSet;
import lombok.extern.slf4j.Slf4j;

G
gaoht 已提交
24 25 26 27
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;

G
gaohongtao 已提交
28 29 30 31 32 33 34 35 36 37 38 39 40
/**
 * 迭代归并结果集.
 *
 * @author gaohongtao
 */
@Slf4j
public class IteratorReducerResultSet extends AbstractResultSetAdapter implements ReducerResultSet {
    
    private int resultSetIndex;
    
    private int currentResultSetOffset;
    
    @Override
G
gaoht 已提交
41
    public void init(final List<ResultSet> preResultSet) {
G
gaohongtao 已提交
42
        setResultSets(preResultSet);
G
gaoht 已提交
43 44
        resultSetIndex++;
        setCurrentResultSet(preResultSet.get(0));
G
gaohongtao 已提交
45 46 47 48 49 50
    }
    
    @Override
    public boolean next() throws SQLException {
        if (null != getCurrentResultSet() && getCurrentResultSet().next()) {
            currentResultSetOffset++;
G
gaoht 已提交
51
            log.trace(toString());
G
gaohongtao 已提交
52 53 54 55 56
            return true;
        }
        if (resultSetIndex >= getResultSets().size()) {
            return false;
        }
G
gaoht 已提交
57
        currentResultSetOffset = 1;
G
gaohongtao 已提交
58 59 60
        ResultSet rs = getResultSets().get(resultSetIndex++);
        setCurrentResultSet(rs);
        log.trace(toString());
G
gaoht 已提交
61
        return rs.next();
G
gaohongtao 已提交
62 63 64 65 66 67 68
    }
    
    @Override
    public String toString() {
        return String.format("Current access %d of %d result set, offset is %d", resultSetIndex, getResultSets().size(), currentResultSetOffset);
    }
}