Search with Linq

by Marre 14. November 2008 11:55

I added a very simple search function on one of my sites. It contain some textboxes and a (search)button. My code behind looks like this:

private void PerformSearch()
{
 DataClassesDataContext
db = new DataClassesDataContext();

  var result = fromquery in db.tblPerson
   where
    (SqlMethods.Like(query.FirstName, "%" + firstName + "%") || firstName == "")
     && (SqlMethods.Like(query.LastName,"%" + lastName + "%") || lastName == "")
   orderby query.LastName, query.FirstName
   select new {query.FirstName, query.LastName, query.Address, query.Phone, query.Mail };

  rSearchResult.DataSource = result;
  rSearchResult.DataBind();
  db.Connection.Close();
}

rSearchResult is a repeater on my .aspx page to witch I bind the result.
The namespace for SqlMethods is System.Data.Linq.SqlClient.

So what is it that I do here? Well...I compare firstName and lastName (strings with search value) with data in my database. But I can also search only on first name or last name, because I also check if the string is blank. So if I leave my Firstname textbox (on my search.aspx page) blank and fill my Lastname textbox with "Andersson", this function will return everyone with Andersson as their last name since my string firstName has the value "".

Be the first to rate this post

  • Currently 0/5 Stars.
  • 1
  • 2
  • 3
  • 4
  • 5

Tags:

Linq

Powered by BlogEngine.NET 1.4.5.0
Theme by Supremelink Development

Martin Andersson

I´m currently working as senior consultant for Capgemini Norway AS.

Curriculum vitae

I use this blog when I find something useful that I want to be able to get hold of wherever I need. But who knows...Maybe someone else will find it useful as well.


About

Supremelink is the name of where I collect my spare time projects. The idea is to learn more about new techniques and areas that I´m not usually is working with or that can be nice to know before future projects at work.

To see the benefits with new technologies and to achieve as much knowledge about those areas, I usually have a goal/project to work with.

This site run´s on BlogEngine.NET. It´s a full featured blog that is using XML as data source. No database is required.

Supreme Software

When I find software that I like and of whitch I can see the benefits to use, I write about it under the category "Supreme Software".

Beware of the soon coming updates in this category!

Tag cloud