SearchQuery 1.0.0.2

There is a newer version of this package available.
See the version list below for details.
dotnet add package SearchQuery --version 1.0.0.2                
NuGet\Install-Package SearchQuery -Version 1.0.0.2                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="SearchQuery" Version="1.0.0.2" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add SearchQuery --version 1.0.0.2                
#r "nuget: SearchQuery, 1.0.0.2"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install SearchQuery as a Cake Addin
#addin nuget:?package=SearchQuery&version=1.0.0.2

// Install SearchQuery as a Cake Tool
#tool nuget:?package=SearchQuery&version=1.0.0.2                

SearchQuery

SearchQuery is a library that extends LINQ search over a database using Entity Framework. SearchQuery isn't tied to any specific database or storage engine and is instead backed by your existing code and data. Search can be done in two interfaces IQueryable, IEnumerable.

The main task is to make the request between Frontend - Backend more flexible and easier to search data.

Info Minimal version is .NET 6.0

npm install jsearchquery

dotnet add package SearchQuery

Warning Important to follow valid json format and type for request condition field type.

Types

A SearchQuery object type at some point those fields have to resolve to some concrete data.

SearchQuery JS/TS SearchQuery .NET .NET
string string string
Date string DateTime, DateOnly, TimeOnly
number number char, byte, sbyte, short, ushort, int, uint, long, ulong, float, double, decimal
boolean boolean boolean
null/undefined null null

Examples

JavaScript/TypeScript

const search = new SearchQuery({
  operator: Operator.And,
  conditions: [
    {
      field: "fullName",
      operation: Operation.Equal,
      values: ["Dennis Ritchie"],
    },
    {
      field: "created",
      // Only two values for Between, NotBetween
      operation: Operation.Between,
      values: ["1990-12-31", "2025-12-31"],
    },
    {
      operator: Operator.Or,
      conditions: [
        {
          field: "fullName",
          operation: Operation.StartsWith,
          values: ["Dennis"],
          case: Case.Lower,
        },
        {
          field: "fullName",
          operation: Operation.EndsWith,
          values: ["Ritchie"],
          case: Case.Upper,
        },
      ],
    },
  ],
});

CSharp

var searchQuery = new Search
{
    Operator = Operator.And,
    Conditions = new Conditions {
        new Condition
        {
            Field = nameof(TestEntity.FullName),
            Operation = Operation.Equal,
            Values = new Values
            {
                "Dennis Ritchie"
            }
        },
        new Condition
        {
            Field = nameof(TestEntity.Created),
            // Only two values for Between, NotBetween
            Operation = Operation.Between,
            Values = new Values
            {
                "1990-12-31", "2025-12-31"
            }
        },
        new Query {
            Operator = Operator.Or,
            Conditions = new Conditions {
                new Condition
                {
                    Field = nameof(TestEntity.FullName),
                    Operation = Operation.StartsWith,
                    Values = new Values
                    {
                        "Dennis"
                    },
                    Case = Case.Lower
                },
                new Condition
                {
                    Field = nameof(TestEntity.FullName),
                    Operation = Operation.EndsWith,
                    Values = new Values
                    {
                        "Ritchie"
                    },
                    Case = Case.Upper
                }
            }
        }
    }
};
using (var db = new Database()) {
    var query = db.Entities.Search(searchQuery).ToList();
}

API

Search Class

Inheritance Query Class

Methods

public string ToJson();

public static Search FromJson(string json);

Query Class

Inheritance ISearch Interface

Property Type Default Description
Operator Operator And And, Or
Conditions Conditions new Conditions() Inherit from List with ISearch generic type
Format Format ISODateTime ISO Formats, DateOnly Formats, TimeOnly Formats

Condition Class

Inheritance ISearch Interface

Property Type Default Description
Field string "" Entity property name
Operation Operation Operation.Equal Action operation
Values Values new Values() Inherit from List with object generic type
Case Case Case.Default Transform string for Contains, NotContains, StartsWith, NotStartsWith, EndsWith, NotEndsWith operation
Format Format ISODateTime ISO Formats, DateOnly Formats, TimeOnly Formats

Conditions Class

Inheritance Base is generic list

Operation Enum

Key Value String Date Number Boolean Null
Equal 0 By Type By Type By Type By Type By Type
NotEqual 1 By Type By Type By Type By Type By Type
LessThan 2 Compare By Type By Type Compare Ignore
LessThanOrEqual 3 Compare By Type By Type Compare Ignore
GreaterThan 4 Compare By Type By Type Compare Ignore
GreaterThanOrEqual 5 Compare By Type By Type Compare Ignore
Contains 6 By Type As String As String As String Ignore
NotContains 7 By Type As String As String As String Ignore
StartsWith 8 By Type As String As String As String Ignore
NotStartsWith 9 By Type As String As String As String Ignore
EndsWith 10 By Type As String As String As String Ignore
NotEndsWith 11 By Type As String As String As String Ignore
Between 12 Compare Compare By Type Compare Ignore
NotBetween 13 Compare Compare By Type Compare Ignore

Case Enum

Key Value
Default 0
Lower 1
Upper 2

Operator Enum

Key Value
And 0
Or 1

Types Enum

Key Value
Null 0
String 1
Number 2
Boolean 3
Date 4

Format Enum

Key Value Format
DateOnly 1 yyyy-MM-dd
TimeOnly 2 HH:mm:ss
ISODateTime 3 yyyy-MM-ddTHH:mm:ss
ISODateTimeWithMilliseconds 4 yyyy-MM-ddTHH:mm:ss.fff
ISODateTimeWithOffset 5 yyyy-MM-ddTHH:mm:sszzz
ISODateTimeUTC 6 yyyy-MM-ddTHH:mm:ssZ
ISODateTimeWithMillisecondsUTC 7 yyyy-MM-ddTHH:mm:ss.fffZ
DateDay 11 dd
DateMonth 12 MM
DateYear 13 yyyy
TimeOn 21 HH:mm
TimeHours 22 HH
TimeMinutes 23 mm
TimeSeconds 24 ss
TimeMilliseconds 25 fff
TimeFull 26 HH:mm:ss.fff
Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.0.4 62 12/21/2024
1.0.0.3 61 12/20/2024
1.0.0.2 56 12/20/2024
1.0.0.1 59 12/19/2024
1.0.0 54 12/19/2024