Veysel Uğur KIZMAZ

Asp.Net MVC 3 & Entity Framework - Proje - Select

16.06.2012Okunma Sayısı: 9796Kategori: ASP.NET MVC

 Bu makalemizde Asp.Net MVC 3 ve Entity Framework kullanarak SELECT işlemini yapıp ekranda göstereceğiz. İlerleyen makalelerimizde bu örnek üzerinden devam ederek INSERT, UPDATE ve DELETE işlemlerini de gerçekleştireceğiz.

 
Veritabanı olarak SQL Server kullanıyorum. “Makale” isminde bir veritabanımız olsun, içinde de Yazar isminde bir tablomuz yer alsın. Yazar tablomuzun yapısı şu şekildedir :
 
 
Yeni bir Asp.Net MVC 3 Web Application – Empty Application oluşturalım (View Engine : Razor)
 
Öncelikle Ado.Net Entity Data Model’imizi “Entity” klasörünün altında oluşturalım.
 
 
Şimdi Yazar işlemlerimizi Entity Data Model’den bağımsız yapabilmek için bir Yazar modeli oluşturuyoruz. (direk veritabanı nesneleriyle değil, kendi ara nesnemizle işlem yapıyoruz.)
 
Bu işlem için Models klasörüne sağ tıklayıp yeni model ekliyoruz.
 
 
  1. public class MYazar
  2. {
  3.     public int YazarId { getset; }
  4.     public string YazarAd { getset; }
  5.     public int MakaleSayisi { getset; }
  6. }
 
Şimdi projemize YazarController isminde bir Empty Controller ekleyelim.
 
Controller’ı ekledikten sonra Controller’ın Index() methodunu şu şekilde düzenleyelim.
 
 
  1. public class YazarController : Controller
  2. {
  3.    private MakaleEntities _entity = new MakaleEntities();
  4.    public ActionResult Index()
  5.     {
  6.         var yazarlar = (from y in _entity.Yazar
  7.                         select new MYazar
  8.                         {
  9.                             YazarId = y.YazarId,
  10.                             YazarAd = y.YazarAd,
  11.                             MakaleSayisi = y.MakaleSayisi
  12.                         }).ToList();
  13.         return View(yazarlar);
  14.     }
  15. }
  
Projemizi bir kere build edelim ve Index() methodumuza sağ tıklayıp Add View diyelim.
 
 
Model Class olarak oluşturduğumuz modeli, template olarak da List’i seçiyoruz. Bu, MYazar değerimizden bir listenin işleme alınacağını belirtir.
 
Yazar/Index.cshtml dosyamızın oluşturulduğundaki kodları aşağıdaki gibidir.
 
Index.cshtml
 
  1. @model IEnumerable<MVCMakale3.Models.MYazar>
  2.  
  3. @{
  4.     ViewBag.Title = "Index";
  5. }
  6.  
  7. <h2>Index</h2>
  8.  
  9. <p>
  10.     @Html.ActionLink("Create New", "Create")
  11. </p>
  12. <table>
  13.     <tr>
  14.         <th>
  15.             YazarId
  16.         </th>
  17.         <th>
  18.             YazarAd
  19.         </th>
  20.         <th>
  21.             MakaleSayisi
  22.         </th>
  23.         <th></th>
  24.     </tr>
  25.  
  26. @foreach (var item in Model) {
  27.     <tr>
  28.         <td>
  29.             @Html.DisplayFor(modelItem => item.YazarId)
  30.         </td>
  31.         <td>
  32.             @Html.DisplayFor(modelItem => item.YazarAd)
  33.         </td>
  34.         <td>
  35.             @Html.DisplayFor(modelItem => item.MakaleSayisi)
  36.         </td>
  37.         <td>
  38.             @Html.ActionLink("Edit", "Edit", new { /* id=item.PrimaryKey */ }) |
  39.            @Html.ActionLink("Details", "Details", new { /* id=item.PrimaryKey */ }) |
  40.             @Html.ActionLink("Delete", "Delete", new { /* id=item.PrimaryKey */ })
  41.         </td>
  42.     </tr>
  43. }
  44.  
  45. </table>

 

 
Burada dikkat etmemiz gereken nokta : @Html.DisplayFor() methodudur. Bu method, parametre olarak aldığı değeri ekranda göstermektedir.
 
@foreach ile Model’deki (List<MYazar>) tüm değerleri tek tek dönüp ekranda yazdırıyoruz.
 
İkinci dikkat edilmesi gereken nokta, sayfanın en üstündeki @model IEnumerable<MVCMakale3.Models.MYazar> satırıdır. Bu satır, modelimizin türünü belirlemektedir. Index.cshtml oluştururken seçtiğiğmiz MYazar’ın tanımlama işlemi bu satır sayesinde gerçekleşmektedir.
 
Global.asax dosyamıza gidelim ve projemizin başlangıç sayfasını Yazar/Index.cshtml yapalım.
 
Global.asax
 
  1. public static void RegisterRoutes(RouteCollection routes)
  2. {
  3.     routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
  4.  
  5.     routes.MapRoute(
  6.         "Default"// Route name
  7.         "{controller}/{action}/{id}"// URL with parameters
  8.         new { controller = "Yazar", action = "Index", id = UrlParameter.Optional } // Parameter defaults
  9.     );
  10.  
  11. }
 
Projemizi çalıştıralım ve sonucunu görelim.
 
 
 
 
Veysel Uğur KIZMAZ
Bilgisayar Mühendisi
veysel@ugurkizmaz.com
www.ugurkizmaz.com