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


Java PreparedStatement類代碼示例

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


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

示例1: getPropertiesValueById

import com.datastax.driver.core.PreparedStatement; //導入依賴的package包/類
@Override
public Response getPropertiesValueById(String keyspaceName, String tableName, String id,
    String... properties) {
  long startTime = System.currentTimeMillis();
  ProjectLogger.log("Cassandra Service getPropertiesValueById method started at ==" + startTime,
      LoggerEnum.PERF_LOG);
  Response response = new Response();
  try {
    String selectQuery = CassandraUtil.getSelectStatement(keyspaceName, tableName, properties);
    PreparedStatement statement = connectionManager.getSession(keyspaceName).prepare(selectQuery);
    BoundStatement boundStatement = new BoundStatement(statement);
    ResultSet results =
        connectionManager.getSession(keyspaceName).execute(boundStatement.bind(id));
    response = CassandraUtil.createResponse(results);
  } catch (Exception e) {
    ProjectLogger.log(Constants.EXCEPTION_MSG_FETCH + tableName + " : " + e.getMessage(), e);
    throw new ProjectCommonException(ResponseCode.SERVER_ERROR.getErrorCode(),
        ResponseCode.SERVER_ERROR.getErrorMessage(), ResponseCode.SERVER_ERROR.getResponseCode());
  }
  long stopTime = System.currentTimeMillis();
  long elapsedTime = stopTime - startTime;
  ProjectLogger.log("Cassandra Service getPropertiesValueById method end at ==" + stopTime
      + " ,Total time elapsed = " + elapsedTime, LoggerEnum.PERF_LOG);
  return response;
}
 
開發者ID:project-sunbird,項目名稱:sunbird-utils,代碼行數:26,代碼來源:CassandraOperationImpl.java

示例2: tuneStatementExecutionOptions

import com.datastax.driver.core.PreparedStatement; //導入依賴的package包/類
/**
 * Tunes CQL statement execution options (consistency level, fetch option and etc.).
 *
 * @param statement Statement.
 * @return Modified statement.
 */
private Statement tuneStatementExecutionOptions(Statement statement) {
    String qry = "";
    if (statement instanceof BoundStatement) {
        qry = ((BoundStatement)statement).preparedStatement().getQueryString().trim().toLowerCase();
    }
    else if (statement instanceof PreparedStatement) {
        qry = ((PreparedStatement)statement).getQueryString().trim().toLowerCase();
    }
    boolean readStatement = qry.startsWith("select");
    boolean writeStatement = statement instanceof Batch || statement instanceof BatchStatement ||
        qry.startsWith("insert") || qry.startsWith("delete") || qry.startsWith("update");
    if (readStatement && readConsistency != null) {
        statement.setConsistencyLevel(readConsistency);
    }
    if (writeStatement && writeConsistency != null) {
        statement.setConsistencyLevel(writeConsistency);
    }
    if (fetchSize != null) {
        statement.setFetchSize(fetchSize);
    }
    return statement;
}
 
開發者ID:epam,項目名稱:Lagerta,代碼行數:29,代碼來源:CassandraSessionImpl.java

示例3: bindKeyValue

import com.datastax.driver.core.PreparedStatement; //導入依賴的package包/類
/**
 * Binds Ignite cache key and value object to {@link PreparedStatement}.
 *
 * @param statement statement to which key and value object should be bind.
 * @param key key object.
 * @param val value object.
 * @return statement with bounded key and value.
 */
public BoundStatement bindKeyValue(PreparedStatement statement, Object key, Object val) {
    KeyPersistenceSettings keySettings = persistenceSettings.getKeyPersistenceSettings();
    Object[] keyValues = getBindingValues(keySettings.getStrategy(),
        keySettings.getSerializer(), keySettings.getFields(), key);
    ValuePersistenceSettings valSettings = persistenceSettings.getValuePersistenceSettings();
    Object[] valValues = getBindingValues(valSettings.getStrategy(),
        valSettings.getSerializer(), valSettings.getFields(), val);
    Object[] values = new Object[keyValues.length + valValues.length];
    int i = 0;
    for (Object keyVal : keyValues) {
        values[i] = keyVal;
        i++;
    }
    for (Object valVal : valValues) {
        values[i] = valVal;
        i++;
    }
    return statement.bind(values);
}
 
開發者ID:epam,項目名稱:Lagerta,代碼行數:28,代碼來源:PersistenceController.java

示例4: main

import com.datastax.driver.core.PreparedStatement; //導入依賴的package包/類
public static void main(String[] args) {

		Session session = Connection.connect();		
		PreparedStatement preparedStatement = session.prepare("insert into user (id, name, age) values (?, ?, ?)");

		try {
			BoundStatement boundStatement = preparedStatement.bind(UUIDs.timeBased(), "Hector", 34);
			ResultSet rs = session.execute(boundStatement);
			System.out.println(rs);
		} catch (Exception ex) {
			ex.printStackTrace();
		}
		
		Connection.close();

	}
 
開發者ID:abulbasar,項目名稱:cassandra-java-driver-examples,代碼行數:17,代碼來源:PreparedStatementExample.java

示例5: main

import com.datastax.driver.core.PreparedStatement; //導入依賴的package包/類
public static void main(String[] args) {

		Session session = Connection.connect();		
		BatchStatement batchStatement = new BatchStatement();
		
		PreparedStatement preparedStatement = session.prepare("insert into user (id, name) values (?, ?)");
		int i = 0;
		while(i < 10) {
			batchStatement.add(preparedStatement.bind(UUIDs.timeBased(), "user-" + i));
			++i;
		}

		try {
			ResultSet rs = session.execute(batchStatement);
			System.out.println(rs);
		} catch (Exception ex) {
			ex.printStackTrace();
		}
		Connection.close();

	}
 
開發者ID:abulbasar,項目名稱:cassandra-java-driver-examples,代碼行數:22,代碼來源:BatchStatementExample.java

示例6: getSaveStmt

import com.datastax.driver.core.PreparedStatement; //導入依賴的package包/類
private PreparedStatement getSaveStmt() {
    if (saveStmt == null) {
        saveStmt = getSession().prepare("INSERT INTO " + ModelConstants.ATTRIBUTES_KV_CF +
                "(" + ENTITY_TYPE_COLUMN +
                "," + ENTITY_ID_COLUMN +
                "," + ATTRIBUTE_TYPE_COLUMN +
                "," + ATTRIBUTE_KEY_COLUMN +
                "," + LAST_UPDATE_TS_COLUMN +
                "," + ModelConstants.STRING_VALUE_COLUMN +
                "," + ModelConstants.BOOLEAN_VALUE_COLUMN +
                "," + ModelConstants.LONG_VALUE_COLUMN +
                "," + ModelConstants.DOUBLE_VALUE_COLUMN +
                ")" +
                " VALUES(?, ?, ?, ?, ?, ?, ?, ?, ?)");
    }
    return saveStmt;
}
 
開發者ID:osswangxining,項目名稱:iotplatform,代碼行數:18,代碼來源:CassandraBaseAttributesDao.java

示例7: getFetchChunksAsyncFunction

import com.datastax.driver.core.PreparedStatement; //導入依賴的package包/類
private AsyncFunction<List<Long>, List<ResultSet>> getFetchChunksAsyncFunction(EntityId entityId, String key, Aggregation aggregation, long startTs, long endTs) {
    return partitions -> {
        try {
            PreparedStatement proto = getFetchStmt(aggregation);
            List<ResultSetFuture> futures = new ArrayList<>(partitions.size());
            for (Long partition : partitions) {
                log.trace("Fetching data for partition [{}] for entityType {} and entityId {}", partition, entityId.getEntityType(), entityId.getId());
                BoundStatement stmt = proto.bind();
                stmt.setString(0, entityId.getEntityType().name());
                stmt.setUUID(1, entityId.getId());
                stmt.setString(2, key);
                stmt.setLong(3, partition);
                stmt.setLong(4, startTs);
                stmt.setLong(5, endTs);
                log.debug("Generated query [{}] for entityType {} and entityId {}", stmt, entityId.getEntityType(), entityId.getId());
                futures.add(executeAsyncRead(stmt));
            }
            return Futures.allAsList(futures);
        } catch (Throwable e) {
            log.error("Failed to fetch data", e);
            throw e;
        }
    };
}
 
開發者ID:osswangxining,項目名稱:iotplatform,代碼行數:25,代碼來源:CassandraBaseTimeseriesDao.java

示例8: getSaveStmt

import com.datastax.driver.core.PreparedStatement; //導入依賴的package包/類
private PreparedStatement getSaveStmt(DataType dataType) {
    if (saveStmts == null) {
        saveStmts = new PreparedStatement[DataType.values().length];
        for (DataType type : DataType.values()) {
            saveStmts[type.ordinal()] = getSession().prepare("INSERT INTO " + ModelConstants.TS_KV_CF +
                    "(" + ModelConstants.ENTITY_TYPE_COLUMN +
                    "," + ModelConstants.ENTITY_ID_COLUMN +
                    "," + ModelConstants.KEY_COLUMN +
                    "," + ModelConstants.PARTITION_COLUMN +
                    "," + ModelConstants.TS_COLUMN +
                    "," + getColumnName(type) + ")" +
                    " VALUES(?, ?, ?, ?, ?, ?)");
        }
    }
    return saveStmts[dataType.ordinal()];
}
 
開發者ID:osswangxining,項目名稱:iotplatform,代碼行數:17,代碼來源:CassandraBaseTimeseriesDao.java

示例9: getSaveTtlStmt

import com.datastax.driver.core.PreparedStatement; //導入依賴的package包/類
private PreparedStatement getSaveTtlStmt(DataType dataType) {
    if (saveTtlStmts == null) {
        saveTtlStmts = new PreparedStatement[DataType.values().length];
        for (DataType type : DataType.values()) {
            saveTtlStmts[type.ordinal()] = getSession().prepare("INSERT INTO " + ModelConstants.TS_KV_CF +
                    "(" + ModelConstants.ENTITY_TYPE_COLUMN +
                    "," + ModelConstants.ENTITY_ID_COLUMN +
                    "," + ModelConstants.KEY_COLUMN +
                    "," + ModelConstants.PARTITION_COLUMN +
                    "," + ModelConstants.TS_COLUMN +
                    "," + getColumnName(type) + ")" +
                    " VALUES(?, ?, ?, ?, ?, ?) USING TTL ?");
        }
    }
    return saveTtlStmts[dataType.ordinal()];
}
 
開發者ID:osswangxining,項目名稱:iotplatform,代碼行數:17,代碼來源:CassandraBaseTimeseriesDao.java

示例10: getFetchStmt

import com.datastax.driver.core.PreparedStatement; //導入依賴的package包/類
private PreparedStatement getFetchStmt(Aggregation aggType) {
    if (fetchStmts == null) {
        fetchStmts = new PreparedStatement[Aggregation.values().length];
        for (Aggregation type : Aggregation.values()) {
            if (type == Aggregation.SUM && fetchStmts[Aggregation.AVG.ordinal()] != null) {
                fetchStmts[type.ordinal()] = fetchStmts[Aggregation.AVG.ordinal()];
            } else if (type == Aggregation.AVG && fetchStmts[Aggregation.SUM.ordinal()] != null) {
                fetchStmts[type.ordinal()] = fetchStmts[Aggregation.SUM.ordinal()];
            } else {
                fetchStmts[type.ordinal()] = getSession().prepare("SELECT " +
                        String.join(", ", ModelConstants.getFetchColumnNames(type)) + " FROM " + ModelConstants.TS_KV_CF
                        + " WHERE " + ModelConstants.ENTITY_TYPE_COLUMN + " = ? "
                        + "AND " + ModelConstants.ENTITY_ID_COLUMN + " = ? "
                        + "AND " + ModelConstants.KEY_COLUMN + " = ? "
                        + "AND " + ModelConstants.PARTITION_COLUMN + " = ? "
                        + "AND " + ModelConstants.TS_COLUMN + " > ? "
                        + "AND " + ModelConstants.TS_COLUMN + " <= ?"
                        + (type == Aggregation.NONE ? " ORDER BY " + ModelConstants.TS_COLUMN + " DESC LIMIT ?" : ""));
            }
        }
    }
    return fetchStmts[aggType.ordinal()];
}
 
開發者ID:osswangxining,項目名稱:iotplatform,代碼行數:24,代碼來源:CassandraBaseTimeseriesDao.java

示例11: getFindLatestStmt

import com.datastax.driver.core.PreparedStatement; //導入依賴的package包/類
private PreparedStatement getFindLatestStmt() {
    if (findLatestStmt == null) {
        findLatestStmt = getSession().prepare("SELECT " +
                ModelConstants.KEY_COLUMN + "," +
                ModelConstants.TS_COLUMN + "," +
                ModelConstants.STRING_VALUE_COLUMN + "," +
                ModelConstants.BOOLEAN_VALUE_COLUMN + "," +
                ModelConstants.LONG_VALUE_COLUMN + "," +
                ModelConstants.DOUBLE_VALUE_COLUMN + " " +
                "FROM " + ModelConstants.TS_KV_LATEST_CF + " " +
                "WHERE " + ModelConstants.ENTITY_TYPE_COLUMN + " = ? " +
                "AND " + ModelConstants.ENTITY_ID_COLUMN + " = ? " +
                "AND " + ModelConstants.KEY_COLUMN + " = ? ");
    }
    return findLatestStmt;
}
 
開發者ID:osswangxining,項目名稱:iotplatform,代碼行數:17,代碼來源:CassandraBaseTimeseriesDao.java

示例12: prepareStatement

import com.datastax.driver.core.PreparedStatement; //導入依賴的package包/類
private PreparedStatement prepareStatement() {
List<ColumnMetadata> partkeys = cluster.getMetadata().getKeyspace(keyspaceName).getTable(tableName).getPartitionKey();
StringBuilder sb = new StringBuilder();
sb.append("SELECT COUNT(*) FROM ");
sb.append(keyspaceName).append(".").append(tableName);
sb.append(" WHERE Token(");
sb.append(partkeys.get(0).getName());
for (int i = 1; i < partkeys.size(); i++)
    sb.append(", ").append(partkeys.get(i).getName());
sb.append(") > ? AND Token(");
sb.append(partkeys.get(0).getName());
for (int i = 1; i < partkeys.size(); i++)
    sb.append(",").append(partkeys.get(i).getName());
sb.append(") <= ?");

debugPrint("Query: " + sb.toString(), true, 2);

return session.prepare(sb.toString()).setConsistencyLevel(consistencyLevel);
   }
 
開發者ID:brianmhess,項目名稱:cassandra-count,代碼行數:20,代碼來源:CqlCount.java

示例13: CassandraConfigDb

import com.datastax.driver.core.PreparedStatement; //導入依賴的package包/類
public CassandraConfigDb(List<String> contactPoints, int port) {
	
	this.contactPoints = new ArrayList<InetAddress> (contactPoints.size());
	
	for (String contactPoint : contactPoints) {
		try {
			this.contactPoints.add(InetAddress.getByName(contactPoint));
		} catch (UnknownHostException e) {
               throw new IllegalArgumentException(e.getMessage());
		}
	}
	
	this.port = port;
	
	cluster = (new Cluster.Builder()).withPort (this.port)
			.addContactPoints(this.contactPoints)
			.withSocketOptions(new SocketOptions().setReadTimeoutMillis(60000).setKeepAlive(true).setReuseAddress(true))
			.withLoadBalancingPolicy(new RoundRobinPolicy())
			.withReconnectionPolicy(new ConstantReconnectionPolicy(500L))
			.withQueryOptions(new QueryOptions().setConsistencyLevel(ConsistencyLevel.ONE))
			.build ();
	
	session = cluster.newSession();
	preparedStatements = new ConcurrentHashMap<StatementName, PreparedStatement> ();
	prepareStatementCreateLock = new Object();
}
 
開發者ID:att,項目名稱:dmaap-framework,代碼行數:27,代碼來源:CassandraConfigDb.java

示例14: createRow

import com.datastax.driver.core.PreparedStatement; //導入依賴的package包/類
private String createRow(String key, String appid, String row) {
	if (StringUtils.isBlank(key) || StringUtils.isBlank(appid) || row == null || row.isEmpty()) {
		return null;
	}
	try {
		// if there isn't a document with the same id then create a new document
		// else replace the document with the same id with the new one
		PreparedStatement ps = getPreparedStatement("INSERT INTO " +
				CassandraUtils.getTableNameForAppid(appid) + " (id, json) VALUES (?, ?);");
		getClient().execute(ps.bind(key, row));
		logger.debug("Created id: " + key + " row: " + row);
	} catch (Exception e) {
		logger.error(null, e);
	}
	return key;
}
 
開發者ID:Erudika,項目名稱:para-dao-cassandra,代碼行數:17,代碼來源:CassandraDAO.java

示例15: updateRow

import com.datastax.driver.core.PreparedStatement; //導入依賴的package包/類
private <P extends ParaObject> void updateRow(P so, String appid) {
	if (so == null || so.getId() == null || StringUtils.isBlank(appid)) {
		return;
	}
	try {
		String oldRow = readRow(so.getId(), appid);
		if (oldRow != null) {
			Map<String, Object> oldData = ParaObjectUtils.getJsonReader(Map.class).readValue(oldRow);
			Map<String, Object> newData = ParaObjectUtils.getAnnotatedFields(so, Locked.class);
			oldData.putAll(newData);
			PreparedStatement ps = getPreparedStatement("UPDATE " +
					CassandraUtils.getTableNameForAppid(appid) + " SET json = ? WHERE id = ?;");
			getClient().execute(ps.bind(ParaObjectUtils.getJsonWriterNoIdent().
					writeValueAsString(oldData), so.getId()));
			logger.debug("Updated id: " + so.getId());
		}
	} catch (Exception e) {
		logger.error(null, e);
	}
}
 
開發者ID:Erudika,項目名稱:para-dao-cassandra,代碼行數:21,代碼來源:CassandraDAO.java


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