ntroduction
In this session we will describe the basic CRUD operations using MVC and Entity Framework.
The main advantage of these parts is we don't need to write any code.
About MVC: ASP.NET MVC Overview
We need to use the following procedure to create our first MVC application.
Procedure
Step 1
In this session we will describe the basic CRUD operations using MVC and Entity Framework.
The main advantage of these parts is we don't need to write any code.
About MVC: ASP.NET MVC Overview
We need to use the following procedure to create our first MVC application.
Procedure
Step 1
Frist step we need to create a new MVC application.
data:image/s3,"s3://crabby-images/cc902/cc9023cab7730bc0a00759dc3968085962977c44" alt="New MVC Application"
Step 2
Step 2
Select the option Internet Application and select the view engine as Razor.
data:image/s3,"s3://crabby-images/b2210/b22104b41d55dc290a154328eb4df9dfd8291427" alt="view engine"
Step 3
Step 3
Now our solution is created.
data:image/s3,"s3://crabby-images/1c97b/1c97bd30d6b11dde88624f948cf0e42eca56d779" alt="my first mvc app"
Step 4
Step 4
A close look at our solution. We are now just concentrating on the three folders Controllers, Models and Views.
data:image/s3,"s3://crabby-images/cfb37/cfb3700bc165363ac268105f781ce437f37cda84" alt="MVC Folders"
Step 5
Step 5
Right-click on the Models => Add=> New Item.
data:image/s3,"s3://crabby-images/0eb17/0eb1726a72e0859af38b6595ac0052c80d3228cc" alt="add new item"
Step 6
Step 6
Select the Data option and click on the Entity Data Model.
data:image/s3,"s3://crabby-images/ca688/ca688a3f4bcdf096360fcedb80b8833812c31a77" alt="ado dotnet entity data model"
Step 7
Step 7
If you want to install the latest version of the Entity Framework then you can install it through Manage NuGet Packages.
data:image/s3,"s3://crabby-images/8d6f0/8d6f0ed72cf5d8cbf7174c72206f5d6f1b0e9896" alt="entity framwork"
Step 8
Step 8
Click on the option Generate from database.
data:image/s3,"s3://crabby-images/00bb3/00bb34b6be0254dd929885d363415911f710a8c2" alt="choose model connection"
Step 9
Step 9
Here we need to create a new database connection.
data:image/s3,"s3://crabby-images/06745/06745582655bc0ef439e37eebd539e463b34d6e8" alt="choose your data connection"
Step 10
Step 10
In this window we need to provide the inputs like our server name and select the database name from the dropdown box .Then we have the option to test our server connection.
data:image/s3,"s3://crabby-images/4ec54/4ec549bfc5c80d12b5dd09464b2e3339231660e0" alt="enter server name"
Step 11
Step 11
The next step is to select the tables from the selected database.
data:image/s3,"s3://crabby-images/e3f46/e3f4670b355480bc084e7268ab2c47a79a02df87" alt="select table"
Step 12
Step 12
Now the .edmx is created and in our model folder the model classes are created.
data:image/s3,"s3://crabby-images/149c5/149c530d80a9743170323f9086be4a2293c692b9" alt="model folder"
Step 13
Step 13
Now we need to create a new controller. Right-click on the Controller then seelct Add => Controller.
data:image/s3,"s3://crabby-images/2566c/2566cf9b335639392debbfcf21ddca4700c2e44c" alt="add controller"
Step 14
Step 14
We need to edit the Controller name and select the Scaffolding options as MVC controller with read/write actions and views, using the Entity Framework.
data:image/s3,"s3://crabby-images/46a36/46a368843b393361f2c4b8fe2809fd19881d27d1" alt="employee controller"
Step 15
Step 15
Likewise select the Model class name and Data context class name.
data:image/s3,"s3://crabby-images/4583c/4583cf57b3d51d3cca233d94cd1cef156df95474" alt="data context class"
Step 16
Step 16
Now our Employee controller is created with some auto-generated code.
data:image/s3,"s3://crabby-images/ffb94/ffb94f2f0a259f63b4d3bb412f87843291c6caec" alt="controller code"
Code
Code
- using System;
- using System.Collections.Generic;
- using System.Data;
- using System.Data.Entity;
- using System.Linq;
- using System.Web;
- using System.Web.Mvc;
- using MyFirstMVCApp.Models;
- namespace MyFirstMVCApp.Controllers
- {
- public class EmployeeController : Controller
- {
- private MVC_TrainingEntities db = new MVC_TrainingEntities();
- //
- // GET: /Employee/
- public ActionResult Index()
- {
- return View(db.Employees.ToList());
- }
- //
- // GET: /Employee/Details/5
- public ActionResult Details(int id = 0)
- {
- Employee employee = db.Employees.Find(id);
- if (employee == null)
- {
- return HttpNotFound();
- }
- return View(employee);
- }
- //
- // GET: /Employee/Create
- public ActionResult Create()
- {
- return View();
- }
- //
- // POST: /Employee/Create
- [HttpPost]
- [ValidateAntiForgeryToken]
- public ActionResult Create(Employee employee)
- {
- if (ModelState.IsValid)
- {
- db.Employees.Add(employee);
- db.SaveChanges();
- return RedirectToAction("Index");
- }
- return View(employee);
- }
- //
- // GET: /Employee/Edit/5
- public ActionResult Edit(int id = 0)
- {
- Employee employee = db.Employees.Find(id);
- if (employee == null)
- {
- return HttpNotFound();
- }
- return View(employee);
- }
- //
- // POST: /Employee/Edit/5
- [HttpPost]
- [ValidateAntiForgeryToken]
- public ActionResult Edit(Employee employee)
- {
- if (ModelState.IsValid)
- {
- db.Entry(employee).State = EntityState.Modified;
- db.SaveChanges();
- return RedirectToAction("Index");
- }
- return View(employee);
- }
- //
- // GET: /Employee/Delete/5
- public ActionResult Delete(int id = 0)
- {
- Employee employee = db.Employees.Find(id);
- if (employee == null)
- {
- return HttpNotFound();
- }
- return View(employee);
- }
- //
- // POST: /Employee/Delete/5
- [HttpPost, ActionName("Delete")]
- [ValidateAntiForgeryToken]
- public ActionResult DeleteConfirmed(int id)
- {
- Employee employee = db.Employees.Find(id);
- db.Employees.Remove(employee);
- db.SaveChanges();
- return RedirectToAction("Index");
- }
- protected override void Dispose(bool disposing)
- {
- db.Dispose();
- base.Dispose(disposing);
- }
- }
- }
Next we need to check our Views folder, yes it has one folder named “Employee” and its views are auto-generated.
data:image/s3,"s3://crabby-images/7a3c9/7a3c98adcfe46e4bb39df6b0509146071eba3cd4" alt="view"
Please have a look at our Index.cshtml.
Please have a look at our Index.cshtml.
- @model IEnumerable<MyFirstMVCApp.Models.Employee>
- @{
- ViewBag.Title = "Index";
- }
- <h2>Index</h2>
- <p>
- @Html.ActionLink("Create New", "Create")
- </p>
- <table>
- <tr>
- <th>
- @Html.DisplayNameFor(model => model.EmpNo)
- </th>
- <th>
- @Html.DisplayNameFor(model => model.EmpName)
- </th>
- <th>
- @Html.DisplayNameFor(model => model.Salary)
- </th>
- <th>
- @Html.DisplayNameFor(model => model.Idx)
- </th>
- <th>
- @Html.DisplayNameFor(model => model.DeptNo)
- </th>
- <th></th>
- </tr>
- @foreach (var item in Model) {
- <tr>
- <td>
- @Html.DisplayFor(modelItem => item.EmpNo)
- </td>
- <td>
- @Html.DisplayFor(modelItem => item.EmpName)
- </td>
- <td>
- @Html.DisplayFor(modelItem => item.Salary)
- </td>
- <td>
- @Html.DisplayFor(modelItem => item.Idx)
- </td>
- <td>
- @Html.DisplayFor(modelItem => item.DeptNo)
- </td>
- <td>
- @Html.ActionLink("Edit", "Edit", new { id = item.EmpNo }) |
- @Html.ActionLink("Details", "Details", new { id = item.EmpNo }) |
- @Html.ActionLink("Delete", "Delete", new { id = item.EmpNo })
- </td>
- </tr>
- }
- </table>
In the App_Start: we need to initialize the starting page in this file.
Open the RouteConfig file and edit the controller name and action name.
data:image/s3,"s3://crabby-images/5a9b4/5a9b46f57280cbd1083fa698f7db7b6588e01875" alt="rought config"
Yes! Our first MVC application is completed.
Open the RouteConfig file and edit the controller name and action name.
Yes! Our first MVC application is completed.
Source Collected from CSharpcorner.com
http://www.c-sharpcorner.com/UploadFile/a9d961/a-quick-start-on-mvc/
No comments:
Post a Comment