public QueryDefinition BuildSqlQuerySpec(SearchOptions searchOptions, QueryBuilderOptions queryOptions = null) { return(new QueryBuilderHelper().BuildSqlQuerySpec(searchOptions, queryOptions ?? new QueryBuilderOptions())); }
public QueryDefinition BuildSqlQuerySpec(SearchOptions searchOptions, QueryBuilderOptions queryOptions) { EnsureArg.IsNotNull(searchOptions, nameof(searchOptions)); EnsureArg.IsNotNull(queryOptions, nameof(queryOptions)); if (searchOptions.CountOnly) { AppendSelectFromRoot("VALUE COUNT(1)"); } else if (queryOptions.Projection == QueryProjection.Id) { AppendSelectFromRoot($"r.{KnownResourceWrapperProperties.ResourceId}", queryOptions.Includes); } else if (queryOptions.Projection == QueryProjection.ReferencesOnly) { AppendSelectFromRoot(string.Empty, queryOptions.Includes); } else { AppendSelectFromRoot(includes: queryOptions.Includes); } AppendSystemDataFilter(); var expressionQueryBuilder = new ExpressionQueryBuilder( _queryBuilder, _queryParameterManager); if (searchOptions.Expression != null) { _queryBuilder.Append("AND "); searchOptions.Expression.AcceptVisitor(expressionQueryBuilder); } AppendFilterCondition( "AND", true, (KnownResourceWrapperProperties.IsHistory, false), (KnownResourceWrapperProperties.IsDeleted, false)); if (!searchOptions.CountOnly) { var hasOrderBy = false; foreach (var sortOptions in searchOptions.Sort) { if (string.Equals(sortOptions.searchParameterInfo.Code, KnownQueryParameterNames.LastUpdated, StringComparison.OrdinalIgnoreCase)) { if (!hasOrderBy) { _queryBuilder.Append("ORDER BY "); hasOrderBy = true; } _queryBuilder.Append(SearchValueConstants.RootAliasName).Append(".") .Append(KnownResourceWrapperProperties.LastModified).Append(" ") .AppendLine(sortOptions.sortOrder == SortOrder.Ascending ? "ASC" : "DESC"); } else { throw new SearchParameterNotSupportedException(string.Format(Core.Resources.SearchSortParameterNotSupported, sortOptions.searchParameterInfo.Code)); } } } var query = new QueryDefinition(_queryBuilder.ToString()); _queryParameterManager.AddToQuery(query); return(query); }
public QueryDefinition BuildSqlQuerySpec(SearchOptions searchOptions, QueryBuilderOptions queryOptions) { EnsureArg.IsNotNull(searchOptions, nameof(searchOptions)); EnsureArg.IsNotNull(queryOptions, nameof(queryOptions)); if (searchOptions.CountOnly) { AppendSelectFromRoot("VALUE COUNT(1)"); } else if (queryOptions.Projection == QueryProjection.IdAndType) { AppendSelectFromRoot($"r.{KnownResourceWrapperProperties.ResourceId}, r.{KnownResourceWrapperProperties.ResourceTypeName}", queryOptions.Includes); } else if (queryOptions.Projection == QueryProjection.ReferencesOnly) { AppendSelectFromRoot(string.Empty, queryOptions.Includes); } else { AppendSelectFromRoot(includes: queryOptions.Includes); } AppendSystemDataFilter(); var expressionQueryBuilder = new ExpressionQueryBuilder( _queryBuilder, _queryParameterManager); if (searchOptions.Expression != null) { _queryBuilder.Append("AND "); searchOptions.Expression.AcceptVisitor(expressionQueryBuilder); } AppendFilterCondition( "AND", true, (KnownResourceWrapperProperties.IsHistory, false), (KnownResourceWrapperProperties.IsDeleted, false)); if (!searchOptions.CountOnly) { if (searchOptions.Sort.Any()) { var sortOption = searchOptions.Sort[0]; _queryBuilder.Append("ORDER BY "); if (string.Equals(sortOption.searchParameterInfo.Code, KnownQueryParameterNames.LastUpdated, StringComparison.OrdinalIgnoreCase)) { #pragma warning disable CA1834 // Consider using 'StringBuilder.Append(char)' when applicable _queryBuilder.Append(SearchValueConstants.RootAliasName).Append('.') #pragma warning restore CA1834 // Consider using 'StringBuilder.Append(char)' when applicable .Append(KnownResourceWrapperProperties.LastModified).Append(' ') .AppendLine(sortOption.sortOrder == SortOrder.Ascending ? "ASC" : "DESC"); } else { #pragma warning disable CA1834 // Consider using 'StringBuilder.Append(char)' when applicable _queryBuilder.Append(SearchValueConstants.RootAliasName) #pragma warning restore CA1834 // Consider using 'StringBuilder.Append(char)' when applicable .Append(".sort[\"").Append(sortOption.searchParameterInfo.Code).Append("\"].") .Append(sortOption.sortOrder == SortOrder.Ascending ? SearchValueConstants.SortLowValueFieldName : SearchValueConstants.SortHighValueFieldName) .Append(' ').AppendLine(sortOption.sortOrder == SortOrder.Ascending ? "ASC" : "DESC"); } } } var query = new QueryDefinition(_queryBuilder.ToString()); _queryParameterManager.AddToQuery(query); return(query); }