當前位置: 首頁>>代碼示例>>Java>>正文


Java LongMapper類代碼示例

本文整理匯總了Java中org.skife.jdbi.v2.util.LongMapper的典型用法代碼示例。如果您正苦於以下問題:Java LongMapper類的具體用法?Java LongMapper怎麽用?Java LongMapper使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


LongMapper類屬於org.skife.jdbi.v2.util包,在下文中一共展示了LongMapper類的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: getDatasetDate

import org.skife.jdbi.v2.util.LongMapper; //導入依賴的package包/類
/** 
 * {@inheritDoc} 
 */
@Override
public Long getDatasetDate(String dataset) {
    try (Handle handle = dbi.open()) {
        return handle.createQuery("select modification_date from dataset_date where dataset = :dataset")
                .bind("dataset", dataset)
                .map(LongMapper.FIRST)
                .first();
    }
}
 
開發者ID:nmdp-bioinformatics,項目名稱:service-epitope,代碼行數:13,代碼來源:DbiManagerImpl.java

示例2: updateDashboard

import org.skife.jdbi.v2.util.LongMapper; //導入依賴的package包/類
@JsonRequest
@ApiOperation(value = "Update dashboard items")
@Path("/update_dashboard_items")
@ProtectEndpoint(writeOperation = true)
public SuccessMessage updateDashboard(
        @Named("user_id") Project project,
        @ApiParam("dashboard") int dashboard,
        @ApiParam("items") List<DashboardItem> items) {
    dbi.inTransaction((handle, transactionStatus) -> {
        Long execute = handle.createQuery("SELECT id FROM dashboard WHERE id = :id AND project_id = :project")
                .bind("id", dashboard)
                .bind("project", project.project)
                .map(LongMapper.FIRST).first();

        if (execute == null) {
            throw new RakamException(HttpResponseStatus.NOT_FOUND);
        }

        for (DashboardItem item : items) {
            // TODO: verify dashboard is in project
            handle.createStatement("UPDATE dashboard_items SET name = :name, directive = :directive, options = :options WHERE id = :id")
                    .bind("id", item.id)
                    .bind("name", item.name)
                    .bind("directive", item.directive)
                    .bind("options", JsonHelper.encode(item.options))
                    .execute();
        }
        return null;
    });
    return SuccessMessage.success();
}
 
開發者ID:rakam-io,項目名稱:rakam,代碼行數:32,代碼來源:DashboardService.java

示例3: getNLastCreatedVertexIds

import org.skife.jdbi.v2.util.LongMapper; //導入依賴的package包/類
/**
 * Find the first N vertex ids order by the txn_start column desc among the specified list of vertex ids
 * @param vertexIds input vertex Ids
 * @param n the first N rows returned by the query
 */
public static List<Long> getNLastCreatedVertexIds(AmberSession sess, List<Long> vertexIds, long n){
    if (CollectionUtils.isNotEmpty(vertexIds)){
        String sql = "SELECT id FROM node WHERE id IN (" + Joiner.on(",").join(vertexIds) + ") GROUP BY id ORDER BY MIN(txn_start) DESC LIMIT :n";
        try (Handle h = sess.getAmberGraph().dbi().open()) {
            return h.createQuery(sql).bind("n", n).map(LongMapper.FIRST).list();
        }
    }
    return new ArrayList<>();
}
 
開發者ID:nla,項目名稱:amberdb,代碼行數:15,代碼來源:WorksQuery.java

示例4: getChildrenIdsByBibLevelSubTypeQuery

import org.skife.jdbi.v2.util.LongMapper; //導入依賴的package包/類
private Query getChildrenIdsByBibLevelSubTypeQuery(Handle h, List<Long> parentIds, BibLevel bibLevel, List<String> subTypes) {
    if (CollectionUtils.isNotEmpty(subTypes)){
        Function<String,String> addQuotes = new Function<String,String>() {
            @Override public String apply(String s) {
                return new StringBuilder(s.length()+2).append("'").append(s).append("'").toString();
            }
        };
        String subTypeStr = Joiner.on(", ").join(Iterables.transform(subTypes, addQuotes));
        return h.createQuery(
                "select distinct v.id from work p1, work p2, flatedge e, node v " +
                        "where p1.id = e.v_out and p2.id = e.v_out and v.id = p1.id and v.id = p2.id " +
                        "and e.label = 'isPartOf' " +
                        "and p1.bibLevel = :bibLevel " +
                        "and p2.subType in ("+ subTypeStr + ") " +
                        "and e.v_in in (" + Joiner.on(",").join(parentIds) + ")")
                .bind("bibLevel", bibLevel.code())
                .map(LongMapper.FIRST);
    }
    return h.createQuery(
            "select distinct v.id from work p1, flatedge e, node v " +
                    "where p1.id = e.v_out and v.id = p1.id " +
                    "and e.label = 'isPartOf' " +
                    "and p1.bibLevel = :bibLevel " +
                    "and e.v_in in (" + Joiner.on(",").join(parentIds) + ")")
            .bind("bibLevel", bibLevel.code())
            .map(LongMapper.FIRST);
}
 
開發者ID:nla,項目名稱:amberdb,代碼行數:28,代碼來源:WorkChildrenQuery.java

示例5: getChildPIs

import org.skife.jdbi.v2.util.LongMapper; //導入依賴的package包/類
public List<String> getChildPIs(String workId) {
    try (Handle h = graph.dbi().open()) {
    	List<Long> objIds = h.createQuery("select v_out from flatedge where v_in = :workId and label = 'isPartOf'")
    		.bind("workId", PIUtil.parse(workId))
    		.map(LongMapper.FIRST)
    		.list();
    	List<String> strings = new ArrayList<>(objIds.size());
    	for (Long objId: objIds) {
    		strings.add(PIUtil.format(objId));
    	}
    	return strings;
    }
}
 
開發者ID:nla,項目名稱:amberdb,代碼行數:14,代碼來源:WorkChildrenQuery.java

示例6: query

import org.skife.jdbi.v2.util.LongMapper; //導入依賴的package包/類
public Query query(Handle h){
    Query q = h.createQuery(sql());
    for (int i=0; i< workProperties.size(); i++){
        q.bind(i, workProperties.get(i).getValue());
    }
    return q.map(LongMapper.FIRST);
}
 
開發者ID:nla,項目名稱:amberdb,代碼行數:8,代碼來源:PropertyQueryAssembler.java

示例7: getAttributes

import org.skife.jdbi.v2.util.LongMapper; //導入依賴的package包/類
@Override
public CompletableFuture<List<String>> getAttributes(String project, String collection, String attribute, Optional<LocalDate> startDate,
                                                     Optional<LocalDate> endDate, Optional<String> filter) {
    long numRows;
    try (Handle handle = dbi.open()) {
        numRows = handle.createQuery("select sum(shards.row_count) as row_count from tables join shards on (shards.table_id = tables.table_id) where table_name = :collection and schema_name = :schema")
                .bind("collection", checkProject(collection))
                .bind("schema", checkProject(project))
                .map(LongMapper.FIRST).iterator().next();
    }

    double samplePercentage;
    double adjustedSamplingThreshold = SAMPLING_THRESHOLD * activeNodeCount.get();
    if (numRows > adjustedSamplingThreshold) {
        samplePercentage = ((adjustedSamplingThreshold / numRows) * 100);
    } else {
        samplePercentage = 100;
    }

    String prestoQuery;
    prestoQuery = format("SELECT DISTINCT %s FROM %s.%s.%s TABLESAMPLE BERNOULLI (%f) WHERE %s IS NOT NULL",
            checkTableColumn(attribute),
            prestoConfig.getColdStorageConnector(),
            checkProject(project, '"'),
            checkCollection(collection, '"'),
            samplePercentage, checkTableColumn(attribute));

    if (startDate.isPresent()) {
        prestoQuery += format(" AND %s >= date '%s'",
                checkTableColumn(projectConfig.getTimeColumn()),
                startDate.get().toString(),
                checkCollection(attribute));
    }

    if (endDate.isPresent()) {
        prestoQuery += format(" AND %s < date '%s'",
                checkTableColumn(projectConfig.getTimeColumn()),
                endDate.get().toString(),
                checkCollection(attribute));
    }

    if (filter.isPresent() && !filter.get().isEmpty()) {
        prestoQuery += String.format(" AND lower(%s) LIKE '%s' ESCAPE '\\'", checkTableColumn(attribute),
                filter.get().replaceAll("%", "\\%").replaceAll("_", "\\_").toLowerCase(ENGLISH) + "%");
    }

    prestoQuery += " LIMIT 10";

    CompletableFuture<QueryResult> result = new PrestoQueryExecution(defaultSession, prestoQuery, true).getResult();
    return result.thenApply(v -> {
        if (v.isFailed()) {
            throw new RakamException(v.getError().message, SERVICE_UNAVAILABLE);
        }

        return v.getResult().stream().map(object -> Objects.toString(object.get(0), null))
                .sorted()
                .collect(Collectors.toList());
    });
}
 
開發者ID:rakam-io,項目名稱:rakam,代碼行數:60,代碼來源:PrestoRakamRaptorMetastore.java


注:本文中的org.skife.jdbi.v2.util.LongMapper類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。