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


Java DbIterator類代碼示例

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


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

示例1: getTransactionIterator

import nxt.util.DbIterator; //導入依賴的package包/類
public static DbIterator<? extends Transaction> getTransactionIterator(
    Long accountId, TransactionType[] recipientTypes,
    TransactionType[] senderTypes, int timestamp, Boolean orderAscending,
    Object referencedTransaction) {
  Connection con = null;
  try {
    con = Db.getConnection();
    PreparedStatement pstmt = createTransactionStatement(con, accountId,
        recipientTypes, senderTypes, timestamp, orderAscending,
        referencedTransaction, false);

    DbIterator<? extends Transaction> iterator = Nxt.getBlockchain()
        .getTransactions(con, pstmt);
    return iterator;
  }
  catch (SQLException e) {
    logger.error("SQL Error", e);
    if (con != null) {
      DbUtils.close(con);
    }
  }
  return null;
}
 
開發者ID:incentivetoken,項目名稱:offspring,代碼行數:24,代碼來源:TransactionDB.java

示例2: getGeneratedBlocks

import nxt.util.DbIterator; //導入依賴的package包/類
public static List<Block> getGeneratedBlocks(Long accountId) {
  Connection con = null;
  try {
    con = Db.getConnection();
    PreparedStatement pstmt = con
        .prepareStatement("SELECT * FROM block WHERE generator_id = ? ORDER BY db_id ASC");
    pstmt.setLong(1, accountId);

    List<Block> result = new ArrayList<Block>();
    DbIterator<? extends Block> iterator = Nxt.getBlockchain().getBlocks(con,
        pstmt);
    while (iterator.hasNext()) {
      result.add(iterator.next());
    }
    return result;
  }
  catch (SQLException e) {
    DbUtils.close(con);
    throw new RuntimeException(e.toString(), e);
  }
}
 
開發者ID:incentivetoken,項目名稱:offspring,代碼行數:22,代碼來源:BlockDB.java

示例3: calculateTransactionsChecksum

import nxt.util.DbIterator; //導入依賴的package包/類
private byte[] calculateTransactionsChecksum() {
    PriorityQueue<Transaction> sortedTransactions = new PriorityQueue<>(blockchain.getTransactionCount(), new Comparator<Transaction>() {
        @Override
        public int compare(Transaction o1, Transaction o2) {
            long id1 = o1.getId();
            long id2 = o2.getId();
            return id1 < id2 ? -1 : (id1 > id2 ? 1 : (o1.getTimestamp() < o2.getTimestamp() ? -1 : (o1.getTimestamp() > o2.getTimestamp() ? 1 : 0)));
        }
    });
    try (DbIterator<TransactionImpl> iterator = blockchain.getAllTransactions()) {
        while (iterator.hasNext()) {
            sortedTransactions.add(iterator.next());
        }
    }
    MessageDigest digest = Crypto.sha256();
    while (! sortedTransactions.isEmpty()) {
        digest.update(sortedTransactions.poll().getBytes());
    }
    return digest.digest();
}
 
開發者ID:aspnmy,項目名稱:NasCoin,代碼行數:21,代碼來源:BlockchainProcessorImpl.java

示例4: getAllBlocks

import nxt.util.DbIterator; //導入依賴的package包/類
public DbIterator<BlockImpl> getAllBlocks()
{
  Connection localConnection = null;
  try
  {
    localConnection = Db.getConnection();
    PreparedStatement localPreparedStatement = localConnection.prepareStatement("SELECT * FROM block ORDER BY db_id ASC");
    new DbIterator(localConnection, localPreparedStatement, new DbIterator.ResultSetReader()
    {
      public BlockImpl get(Connection paramAnonymousConnection, ResultSet paramAnonymousResultSet)
        throws NxtException.ValidationException
      {
        return BlockDb.findBlock(paramAnonymousConnection, paramAnonymousResultSet);
      }
    });
  }
  catch (SQLException localSQLException)
  {
    DbUtils.close(new AutoCloseable[] { localConnection });
    throw new RuntimeException(localSQLException.toString(), localSQLException);
  }
}
 
開發者ID:stevedoe,項目名稱:nxt-client,代碼行數:23,代碼來源:BlockchainImpl.java

示例5: getAllTransactions

import nxt.util.DbIterator; //導入依賴的package包/類
public DbIterator<TransactionImpl> getAllTransactions()
{
  Connection localConnection = null;
  try
  {
    localConnection = Db.getConnection();
    PreparedStatement localPreparedStatement = localConnection.prepareStatement("SELECT * FROM transaction ORDER BY db_id ASC");
    new DbIterator(localConnection, localPreparedStatement, new DbIterator.ResultSetReader()
    {
      public TransactionImpl get(Connection paramAnonymousConnection, ResultSet paramAnonymousResultSet)
        throws NxtException.ValidationException
      {
        return TransactionDb.findTransaction(paramAnonymousConnection, paramAnonymousResultSet);
      }
    });
  }
  catch (SQLException localSQLException)
  {
    DbUtils.close(new AutoCloseable[] { localConnection });
    throw new RuntimeException(localSQLException.toString(), localSQLException);
  }
}
 
開發者ID:stevedoe,項目名稱:nxt-client,代碼行數:23,代碼來源:BlockchainImpl.java

示例6: scan

import nxt.util.DbIterator; //導入依賴的package包/類
public void scan() {
  /* Scan the database */
  TransactionType[] types = { TransactionType.Messaging.ARBITRARY_MESSAGE };
  DbIterator<? extends Transaction> iterator = TransactionDB
      .getTransactionIterator(account.getId(), types, types, 0, Boolean.TRUE,
          null);
  while (iterator.hasNext()) {
    processTransaction(iterator.next());
  }

  /* Add all pending transactions not yet in the database */
  addPendingTransactions();
}
 
開發者ID:incentivetoken,項目名稱:offspring,代碼行數:14,代碼來源:MessageScanner.java

示例7: testListGenesisTransactions

import nxt.util.DbIterator; //導入依賴的package包/類
@Test
public void testListGenesisTransactions() {
  Account account = getGenesisAccount();
  DbIterator<? extends Transaction> iter = Nxt.getBlockchain()
      .getTransactions(account, (byte) -1, (byte) -1, 0);

  int totalAmount = 0;
  while (iter.hasNext()) {
    Transaction txn = iter.next();
    String recipient = Convert.toUnsignedLong(txn.getRecipientId());
    totalAmount += txn.getAmount();
    System.out.println(recipient + " => " + txn.getAmount() + "("
        + totalAmount + ")");
  }
}
 
開發者ID:incentivetoken,項目名稱:offspring,代碼行數:16,代碼來源:TestGenesisTransactions.java

示例8: getAll

import nxt.util.DbIterator; //導入依賴的package包/類
private void getAll(DbIterator<? extends Transaction> iterator,
    List<Transaction> output, ITransactionFilter filter) {
  Transaction transation;
  while (iterator.hasNext()) {
    transation = iterator.next();
    if (filter.accept(transation))
      output.add(transation);
  }
}
 
開發者ID:incentivetoken,項目名稱:offspring,代碼行數:10,代碼來源:NxtDB.java

示例9: getTransactions

import nxt.util.DbIterator; //導入依賴的package包/類
public static LazyList getTransactions(Boolean orderAscending, INxtService nxt) {
  Connection con = null;

  /* Count number of records */
  int available = Nxt.getBlockchain().getTransactionCount();

  /* Create the record iterator */
  try {
    con = Db.getConnection();
    StringBuilder buf = new StringBuilder();
    buf.append("SELECT * FROM transaction ");
    if (orderAscending != null) {
      if (Boolean.TRUE.equals(orderAscending)) {
        buf.append("ORDER BY db_id ASC");
      }
      else if (Boolean.FALSE.equals(orderAscending)) {
        buf.append("ORDER BY db_id DESC");
      }
    }
    PreparedStatement pstmt = con.prepareStatement(buf.toString());
    DbIterator<? extends Transaction> iterator = Nxt.getBlockchain()
        .getTransactions(con, pstmt);
    LazyList lazyList = new LazyList(iterator, available, nxt);
    return lazyList;
  }
  catch (SQLException e) {
    logger.error("SQL Error", e);
    if (con != null) {
      DbUtils.close(con);
    }
  }
  return null;
}
 
開發者ID:incentivetoken,項目名稱:offspring,代碼行數:34,代碼來源:TransactionDB.java

示例10: getForgedBlocks

import nxt.util.DbIterator; //導入依賴的package包/類
@Override
public List<Block> getForgedBlocks() {
  logger.warn("getForgedBlocks()");

  List<Block> result = new ArrayList<Block>();
  Account a = getNative();
  if (a != null) {
    DbIterator<? extends Block> iter = Nxt.getBlockchain().getBlocks(a, 0);
    while (iter.hasNext()) {
      result.add(iter.next());
    }
  }
  return result;
}
 
開發者ID:incentivetoken,項目名稱:offspring,代碼行數:15,代碼來源:AccountHelper.java

示例11: getForgedFee

import nxt.util.DbIterator; //導入依賴的package包/類
@Override
public int getForgedFee() {
  int fee = 0;
  Account a = getNative();
  if (a != null) {
    DbIterator<? extends Block> iter = Nxt.getBlockchain().getBlocks(a, 0);
    while (iter.hasNext()) {
      fee += iter.next().getTotalFee();
    }
  }
  return fee;
}
 
開發者ID:incentivetoken,項目名稱:offspring,代碼行數:13,代碼來源:AccountHelper.java

示例12: getBlocks

import nxt.util.DbIterator; //導入依賴的package包/類
public static LazyList getBlocks(Boolean orderAscending, INxtService nxt) {
  Connection con = null;

  /* Count number of records */
  // int available = nxt.getSmartBlockCount();
  int available = Nxt.getBlockchain().getBlockCount();

  /* Create the record iterator */
  try {
    con = Db.getConnection();
    StringBuilder buf = new StringBuilder();
    buf.append("SELECT * FROM block ");
    if (orderAscending != null) {
      if (Boolean.TRUE.equals(orderAscending)) {
        buf.append("ORDER BY db_id ASC");
      }
      else if (Boolean.FALSE.equals(orderAscending)) {
        buf.append("ORDER BY db_id DESC");
      }
    }
    PreparedStatement pstmt = con.prepareStatement(buf.toString());
    DbIterator<? extends Block> iterator = Nxt.getBlockchain().getBlocks(con,
        pstmt);
    LazyList lazyList = new LazyList(iterator, available);
    return lazyList;
  }
  catch (SQLException e) {
    logger.error("SQL Error", e);
    if (con != null) {
      DbUtils.close(con);
    }
  }
  return null;
}
 
開發者ID:incentivetoken,項目名稱:offspring,代碼行數:35,代碼來源:BlockDB.java

示例13: getAllBlocks

import nxt.util.DbIterator; //導入依賴的package包/類
@Override
public DbIterator<BlockImpl> getAllBlocks() {
    Connection con = null;
    try {
        con = Db.getConnection();
        PreparedStatement pstmt = con.prepareStatement("SELECT * FROM block ORDER BY db_id ASC");
        return getBlocks(con, pstmt);
    } catch (SQLException e) {
        DbUtils.close(con);
        throw new RuntimeException(e.toString(), e);
    }
}
 
開發者ID:aspnmy,項目名稱:NasCoin,代碼行數:13,代碼來源:BlockchainImpl.java

示例14: getBlocks

import nxt.util.DbIterator; //導入依賴的package包/類
@Override
public DbIterator<BlockImpl> getBlocks(Account account, int timestamp) {
    Connection con = null;
    try {
        con = Db.getConnection();
        PreparedStatement pstmt = con.prepareStatement("SELECT * FROM block WHERE timestamp >= ? AND generator_id = ? ORDER BY db_id ASC");
        pstmt.setInt(1, timestamp);
        pstmt.setLong(2, account.getId());
        return getBlocks(con, pstmt);
    } catch (SQLException e) {
        DbUtils.close(con);
        throw new RuntimeException(e.toString(), e);
    }
}
 
開發者ID:aspnmy,項目名稱:NasCoin,代碼行數:15,代碼來源:BlockchainImpl.java

示例15: getAllTransactions

import nxt.util.DbIterator; //導入依賴的package包/類
@Override
public DbIterator<TransactionImpl> getAllTransactions() {
    Connection con = null;
    try {
        con = Db.getConnection();
        PreparedStatement pstmt = con.prepareStatement("SELECT * FROM transaction ORDER BY db_id ASC");
        return getTransactions(con, pstmt);
    } catch (SQLException e) {
        DbUtils.close(con);
        throw new RuntimeException(e.toString(), e);
    }
}
 
開發者ID:aspnmy,項目名稱:NasCoin,代碼行數:13,代碼來源:BlockchainImpl.java


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