I’ve been playing around with ASP.NET MVC for the past few weeks. I’ve got a simple web application with a form which contains a number of drop down lists.
The items in the drop down lists are stored in a database, and I’m using LINQ to SQL to retrieve them.
My question is – where’s the appropriate place to put this code? From what I’ve read so far, it seems that it’s advisible to keep the Controller ‘thin’, but that’s where I currently have this code as it needs to be executed when the page loads.
Where should I be putting DB access code etc.? I’ve included an excerpt from my controller below.
Thanks.
public ActionResult Index()
{
TranslationRequestModel trm = new TranslationRequestModel();
// Get the list of supported languages from the DB
var db = new TransDBDataContext();
IEnumerable<SelectListItem> languages = db.trans_SupportedLanguages
.Select(c => new SelectListItem
{
Value = Convert.ToString(c.ID),
Text = c.Name.ToString()
});
ViewData["SourceLanguages"] = languages;
ViewData["TargetLanguages"] = languages;
return View();
Your database access code should be in a repository. Example:
and the controller would use this repository:
So the basic idea is the following:
As far as the implementation of this repository is concerned feel free to use any data access technology you like (EF, NHibernate, Linq to XML, WCF calls to remote resources over the internet, …)
There are the following advantages:
SelectListItem) and thus are reusable across other types of application than ASP.NET MVC.