This repository and this Readme file, in particular, are in development and are subject to change.
DataGridView
control of Microsoft .NET
framework is a powerful and ubiquitous tool for fetching tabular data from relational databases (e.g. Microsoft Access, MySQL, PostgreSQL, Oracle, etc) and displaying it on the users' screen neatly. Usually, an SQL query would work behind the stage to populate the data that will appear in DataGridView. What happens usually, once the grid is filled, is that the end user is left alone with the data unless more control options are introduced by the developer for working with and analysing the data.
This repository introduces new windows form control extended from the classical DataGridView, that allows the users to define and execute a wide range of logical queries defined in an easy and intuitive form. Here is a sample query build with this control on a datagrid named Test grid
and involving fields named ID
and fullName
:
Search in Test grid WHERE
( <ID> greater or equal 10 ) OR ( <fullName> is Like 'michael' )
The above is nothing more but a plain English text matching its intuitive meaning. Namely, applying this filter on the grid will leave only the rows with ID >= 10
or fullName
containing michael (case insensitive).
In general, each query is built on column names of the original data grid, where columns are joined by logical operators AND
, OR
and NOT
. Various matching operators (e.g. =
, >=
, Like
, etc.) can be applied on columns and the applicability of the operator to the given column is defined by the column's data type. The latter is being determined automatically, but the user is given a chance to adjust it if necessary, in which case the logic of Duck Typing will apply when matching search criteria with the actual data. To summarise:
When using this control, the user does not need to know anything about how SQL works. The tool provides a way to to build queries intiutively, in plain English.
- create and execute a wide range of search queries on your datagridview in seconds. As far as the search operations defined in this control are fixed, the user can build ANY search query defined in logical terms (i.e. using the logical operators
AND
,OR
andNOT
). - save your query in a file and load it later on.
- create search queries using the build-in wizard assistant.
In your project, you will need to add a reference to the DataGridView_withQuery.dll
from this project's Release folder. Afterwards, add a DataGridViw_withQuery
control named, say Datagrid_1
, on a form you wish. Consider filling the SearchFormTitle
property of the grid which controls the caption of the search form (see the Test
project of this repository for an explicit example).
To invoke the search functionality just call the following
this.Datagrid_1.SearchAdvancedStart();
which will open the advanced search form on your screen.
The search query builder on a datagridview. Using this form the user can create and execute search queries involving the columns of the data grid that can be joined in query with various criteria.
The main screen that is used to build the queries looks as follows.
The interface of the query builder. The user can select columns of the grid on which the search will be performed. The search query is automatically transformed into plain English. You can apply the query build here by clicking the Filter button. Follow the Commands button for more options.
The building blocks of the query are the columns of the datagridview. The user can add new rows to the query builder's grid and for each row select a column from a Combobox prefilled by the names of the columns of the datagridview on which the search is performed.
The image below shows this list of columns in an opened form. Each column's data type (String, Numeric, Date, Boolean) is determined automatically and based on these types a list of search operators can be applied to the given column. For example, if the data in a given column is numerical, then one can use =, <>, >=, <= , In Between
operators to define the search condition involving that column.
The query can be build also using the Wizard accessible from the advanced search form (see the Wizard
button). This Wizard is an interface that allows the user to build the query in a step by step fashion.
Once the search query is complete it can be used to filter the data in the grid. The queries can also be saved in a file for later use.
See the Commands
button on the search screen for more options.
There are some caveats one needs to consider. As the development progresses this list will hopefully shrink or disappear.
- A proper error handling is currently missing in the
.dll
- The control has not been tested extensively yet.
- The control works on unbound grids, i.e. no fixed DataSource is supported, and the grid needs to be populated programmatically.
TBA
TBA
Hayk Aleksanyan
TBA