From c1fadddfe8f49ca38e3a07ae81fd3d75f502cb0e Mon Sep 17 00:00:00 2001 From: HBTeun Date: Wed, 30 Mar 2022 10:42:59 +0200 Subject: [PATCH] Disable the use of the nullable type expression for sorting (#171) * Added option to disable creation of sort expression for nullable types * Changed property name. * Updated readme Co-authored-by: Teun Leijten --- README.md | 3 ++- Sieve/Extensions/OrderByDynamic.cs | 10 ++++++---- Sieve/Models/SieveOptions.cs | 2 ++ Sieve/Services/SieveProcessor.cs | 2 +- 4 files changed, 11 insertions(+), 6 deletions(-) diff --git a/README.md b/README.md index f5fd5b1..30fcc20 100644 --- a/README.md +++ b/README.md @@ -129,7 +129,8 @@ Then you can add the configuration: "DefaultPageSize": "int number: optional number to fallback to when no page argument is given. Set <=0 to disable paging if no pageSize is specified (default).", "MaxPageSize": "int number: maximum allowed page size. Set <=0 to make infinite (default)", "ThrowExceptions": "boolean: should Sieve throw exceptions instead of silently failing? Defaults to false", - "IgnoreNullsOnNotEqual": "boolean: ignore null values when filtering using is not equal operator? Default to true" + "IgnoreNullsOnNotEqual": "boolean: ignore null values when filtering using is not equal operator? Defaults to true", + "DisableNullableTypeExpressionForSorting": "boolean: disable the creation of nullable type expression for sorting. Some databases do not handle it (yet). Defaults to false" } } ``` diff --git a/Sieve/Extensions/OrderByDynamic.cs b/Sieve/Extensions/OrderByDynamic.cs index 2483776..aea83a8 100644 --- a/Sieve/Extensions/OrderByDynamic.cs +++ b/Sieve/Extensions/OrderByDynamic.cs @@ -12,9 +12,10 @@ namespace Sieve.Extensions string fullPropertyName, PropertyInfo propertyInfo, bool desc, - bool useThenBy) + bool useThenBy, + bool disableNullableTypeExpression = false) { - var lambda = GenerateLambdaWithSafeMemberAccess(fullPropertyName, propertyInfo); + var lambda = GenerateLambdaWithSafeMemberAccess(fullPropertyName, propertyInfo, disableNullableTypeExpression); var command = desc ? (useThenBy ? "ThenByDescending" : "OrderByDescending") @@ -33,7 +34,8 @@ namespace Sieve.Extensions private static Expression> GenerateLambdaWithSafeMemberAccess ( string fullPropertyName, - PropertyInfo propertyInfo + PropertyInfo propertyInfo, + bool disableNullableTypeExpression ) { var parameter = Expression.Parameter(typeof(TEntity), "e"); @@ -52,7 +54,7 @@ namespace Sieve.Extensions propertyValue = Expression.MakeMemberAccess(propertyValue, propertyInfo); } - if (propertyValue.Type.IsNullable()) + if (propertyValue.Type.IsNullable() && !disableNullableTypeExpression) { nullCheck = GenerateOrderNullCheckExpression(propertyValue, nullCheck); } diff --git a/Sieve/Models/SieveOptions.cs b/Sieve/Models/SieveOptions.cs index 226abe1..af0ee0b 100644 --- a/Sieve/Models/SieveOptions.cs +++ b/Sieve/Models/SieveOptions.cs @@ -11,5 +11,7 @@ public bool ThrowExceptions { get; set; } = false; public bool IgnoreNullsOnNotEqual { get; set; } = true; + + public bool DisableNullableTypeExpressionForSorting { get; set; } = false; } } diff --git a/Sieve/Services/SieveProcessor.cs b/Sieve/Services/SieveProcessor.cs index 5ce5407..4c18644 100644 --- a/Sieve/Services/SieveProcessor.cs +++ b/Sieve/Services/SieveProcessor.cs @@ -365,7 +365,7 @@ namespace Sieve.Services if (property != null) { - result = result.OrderByDynamic(fullName, property, sortTerm.Descending, useThenBy); + result = result.OrderByDynamic(fullName, property, sortTerm.Descending, useThenBy, Options.Value.DisableNullableTypeExpressionForSorting); } else {