I'm trying to create a general search feature that will search the contents of every field in a result set.
So for instance, if I were to write a function in TSQL that returns a result set that contains 100 rows and the fields TicketID
, FirstName
, LastName
and Comment
I want to search each one of those fields for each record for the string 'Mike'.
So essentially if the word 'Mike' is in any of those fields, that record will be included in my search.
How do I do this?
You could create a full Full Text Index. You can have this Index for a whole table or selected columns in the table via a view. http://msdn.microsoft.com/en-us/library/ms142575.aspx#examples It has it own syntax but it is part of the TSQL query and can be combined with regular column search.
from x in someTableOrQuery
where x.FirstName.Contains(str) || x.LastName.Contains(str) || ...
select x
This is just normal C#. No tricks required.
Note that this will translate to a LIKE-expression in SQL. But you won't need to do manual string concatenation which is prone to bugs (not SQL injection in this case).
Or you can use the SqlMethods.Like method, so you are able to search your expression for a specific pattern.
Something like this:
where SqlMethods.Like(str,"%Mike%");
Hope this helps!
The entry for that method would be a DataTable with the resulting set of query's execution. Then you need to iterate on the rows and columns in this way:
foreach (DataRow dr in yourDataTable.Rows)
{
foreach(DataColumn col in yourDataTable.Columns)
{
try
{
if (dr[col].ToString().Contains("Mike"))
{
//Save this one!
}
}
catch
{
//it was not a string, go on then.
}
}
}