Package it.eng.qbe.query

Examples of it.eng.qbe.query.HavingField


      }
    }
    List havingFields = query.getHavingFields();
    Iterator havingFieldsIt = havingFields.iterator();
    while (havingFieldsIt.hasNext()) {
      HavingField havingField = (HavingField) havingFieldsIt.next();
      if (havingField.isPromptable()) {
        // getting filter value on request
        String promptValue = this.getAttributeAsString(havingField.getName());
        logger.debug("Read prompt value [" + promptValue + "] for promptable filter [" + havingField.getName() + "].");
        if (promptValue != null) {
          havingField.getRightOperand().lastValues = new String[] {promptValue}; // TODO how to manage multi-values prompts?;
        }
      }
    }
    logger.debug("OUT");
  }
View Full Code Here


      }
    }
    List havingFields = query.getHavingFields();
    Iterator havingFieldsIt = havingFields.iterator();
    while (havingFieldsIt.hasNext()) {
      HavingField havingField = (HavingField) havingFieldsIt.next();
      if (havingField.isPromptable()) {
        // getting filter value on request
        List promptValuesList = action.getAttributeAsList(havingField.getName());
        if (promptValuesList != null) {
          String[] promptValues = (String[]) promptValuesList.toArray(new String[] {});
          logger.debug("Read prompt value " + promptValues + " for promptable filter " + havingField.getName() + ".");
          havingField.getRightOperand().lastValues = promptValues; // TODO how to manage multi-values prompts?
        }
      }
    }
    logger.debug("OUT");
  }
View Full Code Here

      }
    }
    List havingFields = query.getHavingFields();
    Iterator havingFieldsIt = havingFields.iterator();
    while (havingFieldsIt.hasNext()) {
      HavingField havingField = (HavingField) havingFieldsIt.next();
      if (havingField.isPromptable()) {
        // getting filter value on request
        String promptValue = this.getAttributeAsString(havingField.getName());
        logger.debug("Read prompt value [" + promptValue + "] for promptable filter [" + havingField.getName() + "].");
        if (promptValue != null) {
          havingField.getRightOperand().lastValues = new String[] {promptValue}; // TODO how to manage multi-values prompts?;
        }
      }
    }
    logger.debug("OUT");
  }
View Full Code Here

 
  private JSONArray serializeHavings(Query query, IDataSource dataSource, Locale locale) throws SerializationException {
    JSONArray havingsJSON = new JSONArray();
   
    List havings;
    HavingField filter;
    HavingField.Operand operand;
    JSONObject havingJSON;
    IModelField datamartFilter;
    String fieldUniqueName;
    Iterator it;
    IModelProperties datamartLabels;
    IModelField datamartField;
   
    havings = query.getHavingFields();
    Assert.assertNotNull(havings, "Filters cannot be null");
   
    datamartLabels = null;
    if(locale != null) {
      //datamartLabels =  QbeCacheManager.getInstance().getLabels( dataSource , locale );
      datamartLabels = dataSource.getModelI18NProperties(locale);
    }
   
    it = havings.iterator();
    while( it.hasNext() ) {
      filter = (HavingField)it.next();
     
      havingJSON = new JSONObject();
      try {
        havingJSON.put(QuerySerializationConstants.FILTER_ID, filter.getName());
        havingJSON.put(QuerySerializationConstants.FILTER_DESCRIPTION, filter.getDescription());
        havingJSON.put(QuerySerializationConstants.FILTER_PROMPTABLE, filter.isPromptable());
       
        operand = filter.getLeftOperand();
        havingJSON.put(QuerySerializationConstants.FILTER_LO_VALUE, operand.values[0]);
        if(operand.type.equalsIgnoreCase("Field Content")) {
         
          if(operand.values[0].contains("\"expression\":\"")){
            havingJSON.put(QuerySerializationConstants.FILTER_LO_DESCRIPTION, operand.description );
            String description = operand.values[0].substring(operand.values[0].indexOf("\"expression\":\"")+14);
            description.substring(0, description.indexOf("\""));
            havingJSON.put(QuerySerializationConstants.FILTER_LO_LONG_DESCRIPTION, description);           
          }else{
         
            datamartField = dataSource.getModelStructure().getField( operand.values[0] );
           
            String labelF, labelE;
            labelE = null;
            if(datamartLabels != null) {
              labelE = datamartLabels.getProperty(datamartField.getParent(), "label");
            }
            labelE = StringUtilities.isEmpty(labelE)? datamartField.getParent().getName(): labelE;
           
           
            labelF = null;
            if(datamartLabels != null) {
              labelF = datamartLabels.getProperty(datamartField, "label");
            }
            labelF = StringUtilities.isEmpty(labelF)? datamartField.getName(): labelF;
           
            havingJSON.put(QuerySerializationConstants.FILTER_LO_DESCRIPTION, labelE  + " : " + labelF );
           
            String loLongDescription = getFieldLongDescription(datamartField, datamartLabels);
            havingJSON.put(QuerySerializationConstants.FILTER_LO_LONG_DESCRIPTION, loLongDescription);
 
         
         
        } else if(operand.type.equalsIgnoreCase("Subquery")) {
          String loLongDescription = "Subquery " + operand.description;
          havingJSON.put(QuerySerializationConstants.FILTER_LO_LONG_DESCRIPTION, loLongDescription);
         
          havingJSON.put(QuerySerializationConstants.FILTER_LO_DESCRIPTION, operand.description);
        } else if(operand.type.equalsIgnoreCase("Parent Field Content")) {
          String[] chunks = operand.values[0].split(" ");
          String parentQueryId = chunks[0];
          String fieldName = chunks[1];
          datamartField = dataSource.getModelStructure().getField( fieldName );
          String datamartFieldLongDescription = getFieldLongDescription(datamartField, datamartLabels);
          String loLongDescription = "Query " + parentQueryId + ", " + datamartFieldLongDescription;
          havingJSON.put(QuerySerializationConstants.FILTER_LO_LONG_DESCRIPTION, loLongDescription);
         
          havingJSON.put(QuerySerializationConstants.FILTER_LO_DESCRIPTION, operand.description);
        } else {
          havingJSON.put(QuerySerializationConstants.FILTER_LO_DESCRIPTION, operand.description);
        }
       
       
       
        havingJSON.put(QuerySerializationConstants.FILTER_LO_TYPE, operand.type);
        havingJSON.put(QuerySerializationConstants.FILTER_LO_FUNCTION, operand.function.getName());
        havingJSON.put(QuerySerializationConstants.FILTER_LO_DEFAULT_VALUE, operand.defaulttValues[0]);
        havingJSON.put(QuerySerializationConstants.FILTER_LO_LAST_VALUE, operand.lastValues[0]);
       
        havingJSON.put(QuerySerializationConstants.FILTER_OPERATOR, filter.getOperator());
       
        operand = filter.getRightOperand();
        havingJSON.put(QuerySerializationConstants.FILTER_RO_VALUE, JSONUtils.asJSONArray(operand.values));
        if(operand.type.equalsIgnoreCase("Field Content")) {
          datamartField = dataSource.getModelStructure().getField( operand.values[0] );
         
          String labelF, labelE;
          labelE = null;
          if(datamartLabels != null) {
            labelE = datamartLabels.getProperty(datamartField.getParent(), "label");
          }
          labelE = StringUtilities.isEmpty(labelE)? datamartField.getParent().getName(): labelE;
         
         
          labelF = null;
          if(datamartLabels != null) {
            labelF = datamartLabels.getProperty(datamartField, "label");
          }
          labelF = StringUtilities.isEmpty(labelF)? datamartField.getName(): labelF;
         
          havingJSON.put(QuerySerializationConstants.FILTER_RO_DESCRIPTION, labelE  + " : " + labelF );
         
          String roLongDescription = getFieldLongDescription(datamartField, datamartLabels);
          havingJSON.put(QuerySerializationConstants.FILTER_RO_LONG_DESCRIPTION, roLongDescription);
        } else if(operand.type.equalsIgnoreCase("Subquery")) {
          String roLongDescription = "Subquery " + operand.description;
          havingJSON.put(QuerySerializationConstants.FILTER_RO_LONG_DESCRIPTION, roLongDescription);
         
          havingJSON.put(QuerySerializationConstants.FILTER_RO_DESCRIPTION, operand.description);
        } else if(operand.type.equalsIgnoreCase("Parent Field Content")) {
          String[] chunks = operand.values[0].split(" ");
          String parentQueryId = chunks[0];
          String fieldName = chunks[1];
          datamartField = dataSource.getModelStructure().getField( fieldName );
          String datamartFieldLongDescription = getFieldLongDescription(datamartField, datamartLabels);
          String loLongDescription = "Query " + parentQueryId + ", " + datamartFieldLongDescription;
          havingJSON.put(QuerySerializationConstants.FILTER_RO_LONG_DESCRIPTION, loLongDescription);
         
          havingJSON.put(QuerySerializationConstants.FILTER_RO_DESCRIPTION, operand.description);
        } else {
          havingJSON.put(QuerySerializationConstants.FILTER_RO_DESCRIPTION, operand.description);
        }
        havingJSON.put(QuerySerializationConstants.FILTER_RO_TYPE, operand.type);
        havingJSON.put(QuerySerializationConstants.FILTER_RO_FUNCTION, operand.function.getName());
        havingJSON.put(QuerySerializationConstants.FILTER_RO_DEFAULT_VALUE, JSONUtils.asJSONArray(operand.defaulttValues));
        havingJSON.put(QuerySerializationConstants.FILTER_RO_LAST_VALUE, JSONUtils.asJSONArray(operand.lastValues));
       
        havingJSON.put(QuerySerializationConstants.FILTER_BOOLEAN_CONNETOR, filter.getBooleanConnector());
       
      } catch(JSONException e) {
        throw new SerializationException("An error occurred while serializing filter: " + filter.getName(), e);
      }
      havingsJSON.put(havingJSON);
    }
   
    return havingsJSON;
View Full Code Here

   
    if( query.getHavingFields().size() > 0) {
      buffer.append("HAVING ");
      Iterator it = query.getHavingFields().iterator();
      while (it.hasNext()) {
        HavingField field = (HavingField) it.next();
               
        if(field.getLeftOperand().values[0].contains("expression")){
          IConditionalOperator conditionalOperator = null;
          conditionalOperator = (IConditionalOperator)conditionalOperators.get( field.getOperator() );
          Assert.assertNotNull(conditionalOperator, "Unsopported operator " + field.getOperator() + " used in query definition");

          String havingClauseElement =  buildInLineCalculatedFieldClause(field.getOperator(), field.getLeftOperand(), field.isPromptable(), field.getRightOperand(), query, entityAliasesMaps, conditionalOperator);
          buffer.append(havingClauseElement);
        }else{
            buffer.append( buildHavingClauseElement(field, query, entityAliasesMaps) );
        }
       
        if (it.hasNext()) {
          buffer.append(" " + field.getBooleanConnector() + " ");
        }
      }
    }
   
    return buffer.toString().trim();
View Full Code Here

      }
    }
    List havingFields = query.getHavingFields();
    Iterator havingFieldsIt = havingFields.iterator();
    while (havingFieldsIt.hasNext()) {
      HavingField havingField = (HavingField) havingFieldsIt.next();
      if (havingField.isPromptable()) {
        String key = getParameterKey(havingField.getRightOperand().values[0]);
        if (key != null) {
          String parameterValues = (String) parameters.get(key);
          if (parameterValues != null) {
            String[] promptValues = new String[] {parameterValues}; // TODO how to manage multi-values prompts?
            logger.debug("Read prompt value " + promptValues + " for promptable filter " + havingField.getName() + ".");
            havingField.getRightOperand().lastValues = promptValues;
          }
        }
      }
    }
    logger.debug("OUT");
View Full Code Here

      }
    }
    List havingFields = query.getHavingFields();
    Iterator havingFieldsIt = havingFields.iterator();
    while (havingFieldsIt.hasNext()) {
      HavingField havingField = (HavingField) havingFieldsIt.next();
      if (havingField.isPromptable()) {
        String key = getParameterKey(havingField.getRightOperand().values[0]);
        if (key != null) {
          String parameterValues = (String) parameters.get(key);
          if (parameterValues != null) {
            String[] promptValues = new String[] {parameterValues}; // TODO how to manage multi-values prompts?
            logger.debug("Read prompt value " + promptValues + " for promptable filter " + havingField.getName() + ".");
            havingField.getRightOperand().lastValues = promptValues;
          }
        }
      }
    }
    logger.debug("OUT");
View Full Code Here

   
    //Get the having fields
    List<HavingField> havingFields = query.getHavingFields();
    if(havingFields!=null){
      for(int i=0; i<havingFields.size(); i++){
        HavingField havingField = havingFields.get(i);
        Operand leftOperand = havingField.getLeftOperand();
        if(statement.OPERAND_TYPE_FIELD.equalsIgnoreCase(leftOperand.type)){
          datamartField = statement.getDataSource().getModelStructure().getField( leftOperand.values[0] );
          concernedEntities.add(datamartField.getPathParent());
        }
        Operand rightOperand = havingField.getLeftOperand();
        if(statement.OPERAND_TYPE_FIELD.equalsIgnoreCase(rightOperand.type)){
          datamartField = statement.getDataSource().getModelStructure().getField( rightOperand.values[0] );
          concernedEntities.add(datamartField.getPathParent());
        }
      }
View Full Code Here

   
    if( query.getHavingFields().size() > 0) {
      buffer.append("HAVING ");
      Iterator it = query.getHavingFields().iterator();
      while (it.hasNext()) {
        HavingField field = (HavingField) it.next();
               
        if(field.getLeftOperand().values[0].contains("expression")){
          IConditionalOperator conditionalOperator = null;
          conditionalOperator = (IConditionalOperator)JPQLStatementConditionalOperators.getOperator( field.getOperator() );
          Assert.assertNotNull(conditionalOperator, "Unsopported operator " + field.getOperator() + " used in query definition");

          String havingClauseElement =  buildInLineCalculatedFieldClause(field.getOperator(), field.getLeftOperand(), field.isPromptable(), field.getRightOperand(), query, entityAliasesMaps, conditionalOperator);
          buffer.append(havingClauseElement);
        }else{
            buffer.append( buildHavingClauseElement(field, query, entityAliasesMaps) );
        }
       
        if (it.hasNext()) {
          buffer.append(" " + field.getBooleanConnector() + " ");
        }
      }
    }
   
    return buffer.toString().trim();
View Full Code Here

TOP

Related Classes of it.eng.qbe.query.HavingField

Copyright © 2018 www.massapicom. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.