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


Java DatastoreService.prepare方法代碼示例

本文整理匯總了Java中com.google.appengine.api.datastore.DatastoreService.prepare方法的典型用法代碼示例。如果您正苦於以下問題:Java DatastoreService.prepare方法的具體用法?Java DatastoreService.prepare怎麽用?Java DatastoreService.prepare使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在com.google.appengine.api.datastore.DatastoreService的用法示例。


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

示例1: getLastStatus

import com.google.appengine.api.datastore.DatastoreService; //導入方法依賴的package包/類
private ArrayList<Medicion> getLastStatus(int amountData) {
    // Poner Key estacion + hora_muestra
    Calendar calendarTwoAgo = Calendar.getInstance(TimeZone.getTimeZone("CET"));
    calendarTwoAgo.add(Calendar.DATE, -3);
    Date dateTwoAgo = calendarTwoAgo.getTime();

    // Prepare
    Query.Filter keyFilter = new Query.FilterPredicate(PROPERTY_MEASURE_DATE, Query.FilterOperator.GREATER_THAN, dateTwoAgo);
    Query.Filter no2Filter = new Query.FilterPredicate(PROPERTY_COMPUESTO, Query.FilterOperator.EQUAL, NO2.name());
    List<Query.Filter> filterList = new ArrayList<>();
    filterList.add(keyFilter);
    filterList.add(no2Filter);
    Query.Filter filter = new Query.CompositeFilter(Query.CompositeFilterOperator.AND, filterList);
    Query query = new Query(ENTITY_TYPE_MEDIDAS)
            .setFilter(filter)
            .addSort(PROPERTY_MEASURE_DATE
                    , Query.SortDirection.DESCENDING);

    // Query
    DatastoreService datastore = DatastoreServiceFactory.getDatastoreService();
    PreparedQuery pq = datastore.prepare(query);
    // Get results

    List<com.google.appengine.api.datastore.Entity> resultList = pq.asList(FetchOptions.Builder.withLimit(amountData));
    ArrayList<Medicion> result = new ArrayList<>();
    if (resultList.size()!=0) {
        mLogger.info("Watching " + resultList.size() + " last values of ESTADO");
        for (com.google.appengine.api.datastore.Entity item : resultList){
            result.add(new Medicion((Date) item.getProperty(PROPERTY_MEASURE_DATE), (String) item.getProperty(PROPERTY_AVISO), (String) item.getProperty(PROPERTY_AVISO_STATE), (String) item.getProperty(PREPERTY_AVISO_MAX_TODAY), (String) item.getProperty(PROPERTY_ESCENARIO_STATE_TODAY), (String) item.getProperty(PROPERTY_ESCENARIO_STATE_TOMORROW),  (String) item.getProperty(PROPERTY_ESCENARIO_STATE_TOMORROW_MANUAL) ,isPureMadrid()));
        }
    } else {
        // No hay datos
        mLogger.info("No previous values for ESTADO");
    }
    return result;
}
 
開發者ID:medialab-prado,項目名稱:puremadrid,代碼行數:37,代碼來源:GetNewData.java

示例2: listRawEntity

import com.google.appengine.api.datastore.DatastoreService; //導入方法依賴的package包/類
public Iterable<Entity> listRawEntity(Query q, Boolean returnKeysOnly) {
    DatastoreService datastore = DatastoreServiceFactory.getDatastoreService();
    if (returnKeysOnly) {
        q.setKeysOnly();
    }
    PreparedQuery pq = datastore.prepare(q);
    return pq.asIterable();
}
 
開發者ID:deniotokiari,項目名稱:training-epam-2016,代碼行數:9,代碼來源:StoreServlet.java

示例3: timeZonesArray

import com.google.appengine.api.datastore.DatastoreService; //導入方法依賴的package包/類
public static ArrayList<TimeZone> timeZonesArray() {
    DatastoreService datastore = DatastoreServiceFactory.getDatastoreService();
    Query q = new Query(TimeZone.DatastoreProperties.KIND.getName());
    q.addProjection(new PropertyProjection(TimeZone.DatastoreProperties.TIME_ZONE_ID.getName(), String.class));
    PreparedQuery pq = datastore.prepare(q);
    ArrayList<TimeZone> timeZones = new ArrayList<TimeZone>();
    for(Entity result : pq.asIterable())
        timeZones.add(new TimeZone(result));
    return timeZones;
}
 
開發者ID:kerafill1116,項目名稱:apollo-datastore,代碼行數:11,代碼來源:JSTLFunctions.java

示例4: getSessionsByUserKey

import com.google.appengine.api.datastore.DatastoreService; //導入方法依賴的package包/類
public static ArrayList<Session> getSessionsByUserKey(DatastoreService datastore, Key userKey) {
    Filter userFilter = new FilterPredicate(DatastoreProperties.USER_KEY.getName(), FilterOperator.EQUAL, userKey);
    Query q = new Query(DatastoreProperties.KIND.getName());
    q.setFilter(userFilter);
    PreparedQuery pq = datastore.prepare(q);
    ArrayList<Session> sessions = new ArrayList<Session>();
    for(Entity result : pq.asIterable())
        sessions.add(new Session(result));
    return sessions;
}
 
開發者ID:kerafill1116,項目名稱:apollo-datastore,代碼行數:11,代碼來源:SessionFactory.java

示例5: cleanDatastore

import com.google.appengine.api.datastore.DatastoreService; //導入方法依賴的package包/類
public static void cleanDatastore(DatastoreService ds, String book) {
  Query query = new Query("Greeting")
      .setAncestor(new KeyFactory.Builder("Guestbook", book)
          .getKey()).setKeysOnly();
  PreparedQuery pq = ds.prepare(query);
  List<Entity> entities = pq.asList(FetchOptions.Builder.withDefaults());
  ArrayList<Key> keys = new ArrayList<>(entities.size());

  for (Entity e : entities) {
    keys.add(e.getKey());
  }
  ds.delete(keys);
}
 
開發者ID:GoogleCloudPlatform,項目名稱:java-docs-samples,代碼行數:14,代碼來源:GuestbookTestUtilities.java

示例6: getTallestPeople

import com.google.appengine.api.datastore.DatastoreService; //導入方法依賴的package包/類
private List<Entity> getTallestPeople() {
  DatastoreService datastore = DatastoreServiceFactory.getDatastoreService();

  Query q = new Query("Person").addSort("height", SortDirection.DESCENDING);

  PreparedQuery pq = datastore.prepare(q);
  return pq.asList(FetchOptions.Builder.withLimit(5));
}
 
開發者ID:GoogleCloudPlatform,項目名稱:java-docs-samples,代碼行數:9,代碼來源:QueriesTest.java

示例7: cleanDatastore

import com.google.appengine.api.datastore.DatastoreService; //導入方法依賴的package包/類
public static void cleanDatastore(DatastoreService ds, String book) {
  Query query =
      new Query("Greeting")
          .setAncestor(new KeyFactory.Builder("Guestbook", book).getKey())
          .setKeysOnly();
  PreparedQuery pq = ds.prepare(query);
  List<Entity> entities = pq.asList(FetchOptions.Builder.withDefaults());
  ArrayList<Key> keys = new ArrayList<>(entities.size());

  for (Entity e : entities) {
    keys.add(e.getKey());
  }
  ds.delete(keys);
}
 
開發者ID:GoogleCloudPlatform,項目名稱:java-docs-samples,代碼行數:15,代碼來源:GuestbookTestUtilities.java

示例8: getStatusAt

import com.google.appengine.api.datastore.DatastoreService; //導入方法依賴的package包/類
@ApiMethod(path = "getStatusAt", name = "getStatusAt", httpMethod = ApiMethod.HttpMethod.GET)
    public ApiMedicion getStatusAt(@Named("amount") Date date) {

        Calendar calendar = Calendar.getInstance(TimeZone.getTimeZone("CET"));

//         Fix offset
        if (date.getTime() < 1505341800L * 1000){
            date.setTime(date.getTime() - 3600L * 1000);
        }
        date.setTime(date.getTime());

        calendar.setTime(date);
        calendar.setTimeZone(TimeZone.getTimeZone("CET"));



        // Prepare
        Query.FilterPredicate filter = new Query.FilterPredicate(PROPERTY_MEASURE_DATE, Query.FilterOperator.EQUAL, date);
        Query query = new Query(ENTITY_TYPE_MEDIDAS).setFilter(filter);

        // Query
        DatastoreService datastore = DatastoreServiceFactory.getDatastoreService();
        PreparedQuery pq = datastore.prepare(query);
        List<Entity> resultList = pq.asList(FetchOptions.Builder.withDefaults());

        ApiMedicion medicion = new Medicion(MainServlet.isPureMadrid());
        for (Entity entity : resultList){

            Map<String, Object> properties = entity.getProperties();
            Map<String, Object> mapMeditions = new HashMap<>();

            String propertyCompuesto = (String) entity.getProperty(PROPERTY_COMPUESTO);
            Compuesto compuesto = Compuesto.withName(propertyCompuesto);

            medicion.setMeasuredAt((Date) entity.getProperty(PROPERTY_MEASURE_DATE));
            medicion.setSavedAtHour((Date) entity.getProperty(PROPERTY_SAVED_AT));
            if (entity.getProperty(PROPERTY_COMPUESTO).equals(Compuesto.NO2)){
                medicion.setAviso((String) entity.getProperty(PROPERTY_AVISO));
                medicion.setAvisoState((String) entity.getProperty(PROPERTY_AVISO_STATE));
                medicion.setAvisoMaxToday((String) entity.getProperty(PREPERTY_AVISO_MAX_TODAY));
                medicion.setEscenarioStateToday((String) entity.getProperty(PROPERTY_ESCENARIO_STATE_TODAY));
                medicion.setEscenarioStateTomorrow((String)  entity.getProperty(PROPERTY_ESCENARIO_STATE_TOMORROW));
            }

            for (Map.Entry<String, Object> entry : properties.entrySet()) {
                if(entry.getKey().contains(PROPERTY_ESTACION_BEGINS)){
                    try {
                        mapMeditions.put(entry.getKey(), parseValue(entry.getValue()));
                    } catch (Exception e){
                        mLogger.warning("Error parsing data from Datastore: " + entry.getValue());
                    }
                }
            }
            medicion.put(compuesto,mapMeditions);

        }

        return medicion;
    }
 
開發者ID:medialab-prado,項目名稱:puremadrid,代碼行數:60,代碼來源:PureMadridApi.java

示例9: getImpliedDominantAttributeFilter

import com.google.appengine.api.datastore.DatastoreService; //導入方法依賴的package包/類
/**
 * If there is no filter criteria on the dominant sort attribute, we need
 * to query the database to find the min/max value for the attribute and then
 * apply that to the query.  This is a work-around for broken GAE functionality.
 *
 * @return null if no records in table; otherwise, produce the needed filter.
 * @throws ODKDatastoreException
 */
private SimpleFilterTracker getImpliedDominantAttributeFilter() throws ODKDatastoreException {
  // GAE production throws an exception when a query with equality
  // filters and a sort on a column not constrained by any filter
  // is issued.
  //
  // To work around this, issue a query to return the current min/max
  // value of the dominant sort attribute and apply a GE/LE
  // constraint using that value. This is effectively a no-op,
  // but keeps GAE happy.
  //
  // this is the dominant sort:
  SortTracker dominantSort = sortList.get(0);
  DataField dominantSortAttr = dominantSort.getAttribute();
  SortDirection dominantSortDirection =
      dominantSort.direction.equals(Direction.ASCENDING)
      ? SortDirection.ASCENDING
      : SortDirection.DESCENDING;


  DatastoreService ds = datastore.getDatastoreService();
  EntityRowMapper m = new EntityRowMapper(relation, user);

  Query orderingHack = new com.google.appengine.api.datastore.Query(
      relation.getSchemaName() + "." + relation.getTableName());
  orderingHack.addSort(dominantSort.getAttribute().getName(), dominantSortDirection);

  PreparedQuery orderingPrep = ds.prepare(orderingHack);
  logger.debug("hqrLoop: finding min/max in " + relation.getSchemaName() + "."
      + relation.getTableName() + " of dominantSortAttr: " + dominantSortAttr.getName());

  List<com.google.appengine.api.datastore.Entity> values = orderingPrep
      .asList(FetchOptions.Builder.withDefaults().prefetchSize(1).chunkSize(20).limit(3));
  datastore.recordQueryUsage(relation, values.size());
  if (values == null || values.isEmpty()) {
    // the table is empty -- no need to go further...
    return null;
  }

  Object dominantFilterValue = null;
  // and apply the filter...
  try {
    CommonFieldsBase odkEntity = (CommonFieldsBase) m.mapRow(datastore, values.get(0), 0);
    dominantFilterValue = EngineUtils.getDominantSortAttributeValue(odkEntity, dominantSortAttr);
  } catch (SQLException e) {
    throw new ODKDatastoreException("[" + loggingContextTag + "] Unable to complete request", e);
  }

  SimpleFilterTracker impliedDominantFilter = constructFilter(dominantSortAttr,
      dominantSort.direction.equals(Direction.ASCENDING)
      ? FilterOperation.GREATER_THAN_OR_EQUAL
      : FilterOperation.LESS_THAN_OR_EQUAL, dominantFilterValue );

  return impliedDominantFilter;
}
 
開發者ID:opendatakit,項目名稱:aggregate,代碼行數:63,代碼來源:QueryImpl.java


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