Skip to main content

Managed Query

A simple data structure and set of helper methods to build an abstract representation of a search query.

Managed Query

Query is a small component that is part of Managed.NET. It's a simple data structure and set of helper methods to build an abstract representation of a search query.

The easiest way to explain it's purpose is by example. The examples below use a "Lucene Compiler" which isn't part of Query. It's just one example of how you would make use of the Query object.

Simple AND Field

var luceneString = Query.Field("firstname", "spongebob").And().Field("lastname", "squarepants")
                   .ToQuery()
                   .ToLuceneString();

// OUTPUT: (firstname:"spongebob" AND lastname:"squarepants")

Grouped AND Query

var name = Query.Field("firstname", "spongebob").And().Field("lastname", "squarepants");

var age = Query.Field("age", 30).Or().Field("age", 31);

var luceneString = name.And(age).ToQuery().ToLuceneString();

// OUTPUT: (firstname:"spongebob" AND lastname:"squarepants" AND (age:30 OR age:31))

Grouped AND Query with Range

var name = Query.Field("firstname", "spongebob").And().Field("lastname", "squarepants");

var age = Query.Range("age", 30, 40);

var luceneString = name.And(age).ToQuery(2 /* Page */, 10 /* Page Size */)
                                .OrderByAscending("firstname")
                                .ToLuceneString();

// OUTPUT: (firstname:"spongebob" AND lastname:"squarepants" AND (age:[30 TO 40]))

Hello, my name is Lee and I work as a full-stack web developer specialising in Microsoft ASP.NET technologies. I love using Umbraco and also MANAGED, my own application management software.

Contact me at lee.gunn@secretorange.co.uk

All skills

Contact

Get in touch to talk about your project or just ask me a question.

lee.gunn@secretorange.co.uk