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


Java Transaction類代碼示例

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


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

示例1: update

import org.skife.jdbi.v2.Transaction; //導入依賴的package包/類
public void update(final BusinessContextFactory businessContextFactory) throws AnalyticsRefreshException {
    logService.log(LogService.LOG_DEBUG, "Starting rebuild of Analytics invoices and payments for account " + businessContextFactory.getAccountId());

    // Recompute the account record
    final BusinessAccountModelDao bac = bacFactory.createBusinessAccount(businessContextFactory);

    // Recompute invoice, invoice items and invoice payments records
    final Map<UUID, BusinessInvoiceModelDao> invoices = new HashMap<UUID, BusinessInvoiceModelDao>();
    final Multimap<UUID, BusinessInvoiceItemBaseModelDao> invoiceItems = ArrayListMultimap.<UUID, BusinessInvoiceItemBaseModelDao>create();
    final Multimap<UUID, BusinessPaymentBaseModelDao> invoicePayments = ArrayListMultimap.<UUID, BusinessPaymentBaseModelDao>create();
    createBusinessPojos(businessContextFactory, invoices, invoiceItems, invoicePayments);

    // Delete and recreate all items in the transaction
    executeInTransaction(new Transaction<Void, BusinessAnalyticsSqlDao>() {
        @Override
        public Void inTransaction(final BusinessAnalyticsSqlDao transactional, final TransactionStatus status) throws Exception {
            updateInTransaction(bac, invoices, invoiceItems, invoicePayments, transactional, businessContextFactory.getCallContext());
            return null;
        }
    });

    logService.log(LogService.LOG_DEBUG, "Finished rebuild of Analytics invoices and payments for account " + businessContextFactory.getAccountId());
}
 
開發者ID:killbill,項目名稱:killbill-analytics-plugin,代碼行數:24,代碼來源:BusinessInvoiceAndPaymentDao.java

示例2: update

import org.skife.jdbi.v2.Transaction; //導入依賴的package包/類
public void update(final BusinessContextFactory businessContextFactory) throws AnalyticsRefreshException {
    logService.log(LogService.LOG_DEBUG, "Starting rebuild of Analytics account for account " + businessContextFactory.getAccountId());

    // Recompute the account record
    final BusinessAccountModelDao bac = bacFactory.createBusinessAccount(businessContextFactory);

    executeInTransaction(new Transaction<Void, BusinessAnalyticsSqlDao>() {
        @Override
        public Void inTransaction(final BusinessAnalyticsSqlDao transactional, final TransactionStatus status) throws Exception {
            updateInTransaction(bac, transactional, businessContextFactory.getCallContext());
            return null;
        }
    });

    logService.log(LogService.LOG_DEBUG, "Finished rebuild of Analytics account for account " + businessContextFactory.getAccountId());
}
 
開發者ID:killbill,項目名稱:killbill-analytics-plugin,代碼行數:17,代碼來源:BusinessAccountDao.java

示例3: update

import org.skife.jdbi.v2.Transaction; //導入依賴的package包/類
public void update(final BusinessContextFactory businessContextFactory) throws AnalyticsRefreshException {
    logService.log(LogService.LOG_DEBUG, "Starting rebuild of Analytics subscriptions for account " + businessContextFactory.getAccountId());

    // Recompute the account record
    final BusinessAccountModelDao bac = bacFactory.createBusinessAccount(businessContextFactory);

    // Recompute all invoices and invoice items
    final Collection<BusinessSubscriptionTransitionModelDao> bsts = bstFactory.createBusinessSubscriptionTransitions(businessContextFactory);

    // Recompute the bundle summary records
    final Collection<BusinessBundleModelDao> bbss = bbsFactory.createBusinessBundles(businessContextFactory, bsts);
    executeInTransaction(new Transaction<Void, BusinessAnalyticsSqlDao>() {
        @Override
        public Void inTransaction(final BusinessAnalyticsSqlDao transactional, final TransactionStatus status) throws Exception {
            updateInTransaction(bac, bbss, bsts, transactional, businessContextFactory.getCallContext());
            return null;
        }
    });

    logService.log(LogService.LOG_DEBUG, "Finished rebuild of Analytics subscriptions for account " + businessContextFactory.getAccountId());
}
 
開發者ID:killbill,項目名稱:killbill-analytics-plugin,代碼行數:22,代碼來源:BusinessSubscriptionTransitionDao.java

示例4: getOrAddSource

import org.skife.jdbi.v2.Transaction; //導入依賴的package包/類
@Override
public int getOrAddSource(final String source, final CallContext context) throws UnableToObtainConnectionException, CallbackFailedException {

    final Integer result = delegate.inTransaction(new Transaction<Integer, TimelineSqlDao>() {

        @Override
        public Integer inTransaction(final TimelineSqlDao transactional, final TransactionStatus status) throws Exception {
            return getOrAddWithRetry(new Callable<Integer>() {
                @Override
                public Integer call() throws Exception {
                    final MeterInternalTenantContext internalTenantContext = createInternalTenantContext(context);
                    final MeterInternalCallContext internalCallContext = createInternalCallContext(context);
                    Integer sourceId = transactional.getSourceRecordId(source, internalTenantContext);
                    if (sourceId == null) {
                        transactional.addSource(source, internalCallContext);
                        sourceId = transactional.getSourceRecordId(source, internalTenantContext);
                    }
                    return sourceId;
                }
            });
        }
    });
    return result;
}
 
開發者ID:killbill,項目名稱:killbill-meter-plugin,代碼行數:25,代碼來源:DefaultTimelineDao.java

示例5: getOrAddEventCategory

import org.skife.jdbi.v2.Transaction; //導入依賴的package包/類
@Override
public int getOrAddEventCategory(final String eventCategory, final CallContext context) throws UnableToObtainConnectionException, CallbackFailedException {

    final Integer result = delegate.inTransaction(new Transaction<Integer, TimelineSqlDao>() {

        @Override
        public Integer inTransaction(final TimelineSqlDao transactional, final TransactionStatus status) throws Exception {
            return getOrAddWithRetry(new Callable<Integer>() {
                @Override
                public Integer call() throws Exception {
                    final MeterInternalTenantContext internalTenantContext = createInternalTenantContext(context);
                    final MeterInternalCallContext internalCallContext = createInternalCallContext(context);
                    Integer eventCategoryId = transactional.getCategoryRecordId(eventCategory, internalTenantContext);
                    if (eventCategoryId == null) {
                        transactional.addCategory(eventCategory, internalCallContext);
                        eventCategoryId = transactional.getCategoryRecordId(eventCategory, internalTenantContext);
                    }
                    return eventCategoryId;
                }
            });
        }
    });
    return result;
}
 
開發者ID:killbill,項目名稱:killbill-meter-plugin,代碼行數:25,代碼來源:DefaultTimelineDao.java

示例6: getOrAddMetric

import org.skife.jdbi.v2.Transaction; //導入依賴的package包/類
@Override
public synchronized int getOrAddMetric(final Integer eventCategoryId, final String metric, final CallContext context) throws UnableToObtainConnectionException, CallbackFailedException {

    final Integer result = delegate.inTransaction(new Transaction<Integer, TimelineSqlDao>() {

        @Override
        public Integer inTransaction(final TimelineSqlDao transactional, final TransactionStatus status) throws Exception {
            return getOrAddWithRetry(new Callable<Integer>() {
                @Override
                public Integer call() throws Exception {
                    final MeterInternalTenantContext internalTenantContext = createInternalTenantContext(context);
                    final MeterInternalCallContext internalCallContext = createInternalCallContext(context);
                    Integer metricId = transactional.getMetricRecordId(eventCategoryId, metric, internalTenantContext);
                    if (metricId == null) {
                        transactional.addMetric(eventCategoryId, metric, internalCallContext);
                        metricId = transactional.getMetricRecordId(eventCategoryId, metric, internalTenantContext);
                    }
                    return metricId;
                }
            });
        }
    });
    return result;
}
 
開發者ID:killbill,項目名稱:killbill-meter-plugin,代碼行數:25,代碼來源:DefaultTimelineDao.java

示例7: executeInTransaction

import org.skife.jdbi.v2.Transaction; //導入依賴的package包/類
public void executeInTransaction(final Transaction<Void, BusinessAnalyticsSqlDao> transaction) {
    // In REPEATABLE READ, every lock acquired during a transaction is held for the duration of the transaction.
    // In READ COMMITTED the locks that did not match the scan are released after the STATEMENT completes.
    // We need to make sure to use READ COMMITTED here, to avoid MySQL deadlocks under high load. This should
    // not have any impact in these transactions as we only delete & re-insert rows on a per account basis,
    // and accounts are not updated in parallel (not enforced, but we try hard not to).
    sqlDao.inTransaction(TransactionIsolationLevel.READ_COMMITTED, transaction);
}
 
開發者ID:killbill,項目名稱:killbill-analytics-plugin,代碼行數:9,代碼來源:BusinessAnalyticsDaoBase.java

示例8: update

import org.skife.jdbi.v2.Transaction; //導入依賴的package包/類
public void update(final BusinessContextFactory businessContextFactory) throws AnalyticsRefreshException {
    logService.log(LogService.LOG_DEBUG, "Starting rebuild of Analytics custom fields for account " + businessContextFactory.getAccountId());

    final BusinessModelDaosWithAccountAndTenantRecordId<BusinessFieldModelDao> fieldModelDaos = bFieldFactory.createBusinessFields(businessContextFactory);

    executeInTransaction(new Transaction<Void, BusinessAnalyticsSqlDao>() {
        @Override
        public Void inTransaction(final BusinessAnalyticsSqlDao transactional, final TransactionStatus status) throws Exception {
            updateInTransaction(fieldModelDaos, transactional, businessContextFactory.getCallContext());
            return null;
        }
    });

    logService.log(LogService.LOG_DEBUG, "Finished rebuild of Analytics custom fields for account " + businessContextFactory.getAccountId());
}
 
開發者ID:killbill,項目名稱:killbill-analytics-plugin,代碼行數:16,代碼來源:BusinessFieldDao.java

示例9: update

import org.skife.jdbi.v2.Transaction; //導入依賴的package包/類
public void update(final BusinessContextFactory businessContextFactory) throws AnalyticsRefreshException {
    logService.log(LogService.LOG_DEBUG, "Starting rebuild of Analytics tags for account " + businessContextFactory.getAccountId());

    final BusinessModelDaosWithAccountAndTenantRecordId<BusinessTagModelDao> tagModelDaos = bTagFactory.createBusinessTags(businessContextFactory);

    executeInTransaction(new Transaction<Void, BusinessAnalyticsSqlDao>() {
        @Override
        public Void inTransaction(final BusinessAnalyticsSqlDao transactional, final TransactionStatus status) throws Exception {
            updateInTransaction(tagModelDaos, transactional, businessContextFactory.getCallContext());
            return null;
        }
    });

    logService.log(LogService.LOG_DEBUG, "Finished rebuild of Analytics tags for account " + businessContextFactory.getAccountId());
}
 
開發者ID:killbill,項目名稱:killbill-analytics-plugin,代碼行數:16,代碼來源:BusinessTagDao.java

示例10: update

import org.skife.jdbi.v2.Transaction; //導入依賴的package包/類
public void update(final BusinessContextFactory businessContextFactory) throws AnalyticsRefreshException {
    logService.log(LogService.LOG_DEBUG, "Starting rebuild of Analytics account transitions for account " + businessContextFactory.getAccountId());

    final Collection<BusinessAccountTransitionModelDao> businessAccountTransitions = bosFactory.createBusinessAccountTransitions(businessContextFactory);

    executeInTransaction(new Transaction<Void, BusinessAnalyticsSqlDao>() {
        @Override
        public Void inTransaction(final BusinessAnalyticsSqlDao transactional, final TransactionStatus status) throws Exception {
            updateInTransaction(businessAccountTransitions, transactional, businessContextFactory.getCallContext());
            return null;
        }
    });

    logService.log(LogService.LOG_DEBUG, "Finished rebuild of Analytics account transitions for account " + businessContextFactory.getAccountId());
}
 
開發者ID:killbill,項目名稱:killbill-analytics-plugin,代碼行數:16,代碼來源:BusinessAccountTransitionDao.java

示例11: insertTimelineChunk

import org.skife.jdbi.v2.Transaction; //導入依賴的package包/類
@Override
public Long insertTimelineChunk(final TimelineChunk timelineChunk, final CallContext context) throws UnableToObtainConnectionException, CallbackFailedException {

    final Long result = delegate.inTransaction(new Transaction<Long, TimelineSqlDao>() {
        @Override
        public Long inTransaction(final TimelineSqlDao transactional, final TransactionStatus status) throws Exception {
            final MeterInternalTenantContext internalTenantContext = createInternalTenantContext(context);
            final MeterInternalCallContext internalCallContext = createInternalCallContext(context);
            transactional.insertTimelineChunk(timelineChunk, internalCallContext);
            final long timelineChunkId = transactional.getLastInsertedRecordId(internalTenantContext);
            return timelineChunkId;
        }
    });
    return result;
}
 
開發者ID:killbill,項目名稱:killbill-meter-plugin,代碼行數:16,代碼來源:DefaultTimelineDao.java


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