ASP.NET MVC (Fatura Kayıtları) - Veri Modelleri
- 871
- (1)
- (5)
- 05 Şub 2018
InvoicesWeb projesi içerisinde MS-SQL' den InvoicesDB veritabanına ait tanımlanmış prosedürleri çalıştıracak ve bilgi çekebilecek veri modelleri tanımlayabilirsiniz. Bu veri modellerini doğrudan tabloların şemalarıyla özdeş olarak Entity Framework ile oluşturabilirsiniz. Ancak bu içerikte bu proje için daha temel bir teknik olan ADO.NET kullanılacaktır. Daha sonraki içeriklerde Entity Framework ile geliştirebilir projelere de mutlaka değinilecektir.
Veritabanı Bağlantısı
Veritabanı bağlantısı için Web.config
dosyasında bir adet ConnectionString
oluşturabilirsiniz. Her bağlantı işleminde bu bağlantı metnini çağıracağınız için, eğer sonradan değişirse tek bir yerden değiştirmeniz daha kolay olacaktır.
Web.config
dosyasında configuration
içerisinde connectionStrings
isimli bir öğe oluşturarak bağlantı metnini yazabilirsiniz.
<configuration>
<connectionStrings>
<add name="ConnString" connectionString="Data Source=.\SQLEXPRESS; Initial Catalog=InvoicesDB; Integrated Security=True;"/>
</connectionStrings>
...
...
...
</configuration>
Models dizini içerisinde IProcedure
isimli bir interface
oluşturup bütün veri modellerinde kullanarak ortak metotları kullanabilirsiniz.
interface IProcedure
{
SqlCommand ToCreateCommand(SqlConnection connection);
SqlCommand ToUpdateCommand(SqlConnection connection);
SqlCommand ToDeleteCommand(SqlConnection connection);
}
Bu üç metot bütün veri modellerinde mevcut olacağı için, her veritabanı bağlantısında ayrı class
üzerinden değil tek bir interface
üzerinden bu metotları çağırabilirsiniz.
Veritabanı işlemleri için bir katman oluşturup genel bütün metotları burada tanımlayabilirsiniz. Proje içerisinde Helpers isimli bir dizin oluşturabilirsiniz. Solution Explorer üzerinde proje adına (InvoiceWeb) sağ tıklayıp Add menüsünden New Folder ile yeni dizin oluşturup adını Helpers olarak girin.
Bu dizine de sağ tıklayıp Add menüsünden Class tuşuna tıklayıp DBHelper
isimli yeni bir sınıf oluşturun.
public class DBHelper
{
// Bağlantı metni
private string ConnectionString { get { return System.Configuration.ConfigurationManager.ConnectionStrings["ConnString"].ConnectionString; } }
// Veritabanına bağlanıp, SqlConnection türünde bağlantı nesnesini döndüren metot
private async Task<SqlConnection> OpenConnection()
{
SqlConnection connection = new SqlConnection(ConnectionString);
await connection.OpenAsync();
return connection;
}
// Bağlantıyı kapatma metodu
private void CloseConnection(SqlConnection connection)
{
connection.Close(); connection.Close();
}
// IProcedure arabirimi olan her veri türü için oluşturma prosedürü çalıştıran metot
public async Task<DBResult> CreateProcedure(IProcedure procedure)
{
var connection = await OpenConnection(); // bağlantı açılır
var command = procedure.ToCreateCommand(connection); // müşteri, fatura veya fatura satırı oluşturma prosedürü için komut oluşturur
var dataReader = await command.ExecuteReaderAsync(); // komutu çalıştırıp SqlDataReader nesnesine geri dönüş yapar
DBResult result = new DBResult(); // geri dönüş için DBResult türünde tanımlı veri
await result.GetFromDataReader(dataReader); // prosedürün sonucu okunur
CloseConnection(connection); // bağlantı kapanır
return result; // result nesnesi metodun dönüş değeridir
}
// IProcedure arabirimi olan her veri türü için güncelleme prosedürü çalıştıran metot
public async Task<DBResult> UpdateProcedure(IProcedure procedure)
{
var connection = await OpenConnection();
var command = procedure.ToUpdateCommand(connection);
var dataReader = await command.ExecuteReaderAsync();
DBResult result = new DBResult();
await result.GetFromDataReader(dataReader);
CloseConnection(connection);
return result;
}
// IProcedure arabirimi olan her veri türü için silme prosedürü çalıştıran metot
public async Task<DBResult> DeleteProcedure(IProcedure procedure)
{
var connection = await OpenConnection();
var command = procedure.ToDeleteCommand(connection);
var dataReader = await command.ExecuteReaderAsync();
DBResult result = new DBResult();
await result.GetFromDataReader(dataReader);
CloseConnection(connection);
return result;
}
/* Müşteri oluşturma veya düzenleme sayfalarında müşteri durum ve
türü seçebilmek için bu değerlerin veritabanından çekilmesi gereklidir */
public async Task<CustomerValuesModel> GetCustomerValues()
{
var connection = await OpenConnection();
var command = new SqlCommand("select * from tblCustomerTypes select * from tblCustomerStatuses", connection);
var dataReader = await command.ExecuteReaderAsync();
List<CustomerTypeModel> customerTypes = new List<CustomerTypeModel>();
while (await dataReader.ReadAsync())
{
CustomerTypeModel customerType = new CustomerTypeModel();
customerType.GetFromDataReader(dataReader);
customerTypes.Add(customerType);
}
await dataReader.NextResultAsync();
List<CustomerStatusModel> customerStatuses = new List<CustomerStatusModel>();
while (await dataReader.ReadAsync())
{
CustomerStatusModel customerStatus = new CustomerStatusModel();
customerStatus.GetFromDataReader(dataReader);
customerStatuses.Add(customerStatus);
}
CloseConnection(connection);
return new CustomerValuesModel() { CustomerTypes = customerTypes, CustomerStatuses = customerStatuses };
}
}
Models Dizini
Solution Explorer üzerinde Models dizini içerisinde yeni sınıflar oluşturarak bu sınıflarla veritabanına bağlantı sağlayıp bilgi alışverişinde bulunulabilir. Örneğin Fatura Kayıtları (InvoicesWeb) projesi için Veritabanı içeriğinde çok sayıda prosedür yazılmıştı. Bunlardan müşteri kayıtları ile ilgili olan prosedürleri kullanarak başlayabilirsiniz.
dbo.procCreateCustomer
prosedürü ile müşteri oluşturmak, dbo.procUpdateCustomer
prosedürü ile müşteri bilgileri güncellemek, dbo.procDeleteCustomer
prosedürü ile de müşteriyi silmek mümkündür.
Müşteri Veri Modeli
Models dizinine sağ tıklayıp Add menüsünden Class tuşuna tıklayın. Karşınıza gelecek ekrandan yeni bir class
oluşturabileceğiniz dosyanın adını girip menüden Class seçeneğinin seçili olduğundan da emin olun. Class ismi olarak CustomerModel
ismini girin. Ardından sınıf modeli oluşturulacaktır.
Veri modelini aşağıdaki gibi kodlayabilirsiniz. CustomerModel
sınıfına IProcedure
arabirimini uygulamalısınız.
public class CustomerModel: IProcedure
{
public int CustomerId { get; set; }
public string Name { get; set; }
public int CustomerTypeId { get; set; }
public string CustomerType { get; private set; }
public int CustomerStatusId { get; set; }
public string CustomerStatus { get; private set; }
public string Email { get; set; }
public string Phone { get; set; }
public string TaxNumber { get; set; }
public string Address { get; set; }
public DateTime Register { get; set; }
// SqlDataReader ile sorgu okunurken bu metot ile veriler alınacak
public void GetFromDataReader(SqlDataReader dataReader)
{
CustomerId = Convert.ToInt32(dataReader["colCustomerId"]);
Name = dataReader["colName"].ToString();
CustomerType = dataReader["colCustomerType"].ToString();
CustomerStatus = dataReader["colCustomerStatus"].ToString();
Email = dataReader["colEmail"].ToString();
Phone = dataReader["colPhone"].ToString();
TaxNumber = dataReader["colTaxNumber"].ToString();
Address = dataReader["colAddress"].ToString();
Register = Convert.ToDateTime(dataReader["colRegister"]);
}
public SqlCommand ToCreateCommand(SqlConnection connection)
{
// SqlCommand ile prosedür çalıştıracağımız için CommandType değeri StoredProcedure olmalı
SqlCommand command = new SqlCommand("dbo.procCreateCustomer", connection)
{ CommandType = System.Data.CommandType.StoredProcedure };
// Parametreler
//@_name nvarchar(128), @_customerTypeID int, @_customerStatusID int, @_email varchar(64)
//@_phone varchar(32), @_taxNumber varchar(32), @_address nvarchar(256)
command.Parameters.AddRange(new SqlParameter[] { PrmName, PrmCustomerTypeId, PrmCustomerStatusId,
PrmEmail, PrmPhone, PrmTaxNumber, PrmAddress });
return command;
}
public SqlCommand ToUpdateCommand(SqlConnection connection)
{
// SqlCommand ile prosedür çalıştıracağımız için CommandType değeri StoredProcedure olmalı
SqlCommand command = new SqlCommand("dbo.procUpdateCustomer", connection)
{ CommandType = System.Data.CommandType.StoredProcedure };
// Parametreler
//@_name nvarchar(128), @_customerTypeID int, @_customerStatusID int, @_email varchar(64)
//@_phone varchar(32), @_taxNumber varchar(32), @_address nvarchar(256)
command.Parameters.AddRange(new SqlParameter[] { PrmCustomerId, PrmName, PrmCustomerTypeId, PrmCustomerStatusId,
PrmEmail, PrmPhone, PrmTaxNumber, PrmAddress });
return command;
}
public SqlCommand ToDeleteCommand(SqlConnection connection)
{
// SqlCommand ile prosedür çalıştıracağımız için CommandType değeri StoredProcedure olmalı
SqlCommand command = new SqlCommand("dbo.procDeleteCustomer", connection)
{ CommandType = System.Data.CommandType.StoredProcedure };
// Parametreler
//@_customerId int
command.Parameters.AddRange(new SqlParameter[] { PrmCustomerId });
return command;
}
// Aşağıda sadece get metodu ile enkapsüle edilmiş özellikler tanımlandı
// bu özellikler SqlCommand nesneleri için parametre olarak kullanılacak
private SqlParameter PrmCustomerId { get { return new SqlParameter("@_customerId", System.Data.SqlDbType.Int) { Value = CustomerId }; } }
private SqlParameter PrmName { get { return new SqlParameter("@_name", System.Data.SqlDbType.NVarChar, 128) { Value = Name }; } }
private SqlParameter PrmCustomerTypeId { get { return new SqlParameter("@_customerTypeID", System.Data.SqlDbType.Int) { Value = CustomerTypeId }; } }
private SqlParameter PrmCustomerStatusId { get { return new SqlParameter("@_customerStatusID", System.Data.SqlDbType.Int) { Value = CustomerStatusId }; } }
private SqlParameter PrmEmail { get { return new SqlParameter("@_email", System.Data.SqlDbType.VarChar, 64) { Value = Email }; } }
private SqlParameter PrmPhone { get { return new SqlParameter("@_phone", System.Data.SqlDbType.VarChar, 32) { Value = Phone }; } }
private SqlParameter PrmTaxNumber { get { return new SqlParameter("@_taxNumber", System.Data.SqlDbType.VarChar, 32) { Value = TaxNumber }; } }
private SqlParameter PrmAddress { get { return new SqlParameter("@_address", System.Data.SqlDbType.NVarChar, 256) { Value = Address }; } }
}
Veri modelinde, veritabanındaki ilgili tabloya (tblCustomers
) ve ilgili prosedürlere karşılık gelen özellikler belirlenir.
GetFromDataReader
metodu müşteriler okunurken çalıştırılacak, ToCreateCommand
müşteri oluşturma formundan okunan bilgileri kullanacak, ToUpdateCommand
müşteri güncelleme formundan okunan bilgileri kullanacak.
CustomerModel
sınıfının bittiği yerde hemen altına aşağıdaki sınıfları tanımlayın. CustomerTypeModel
ve CustomerStatusModel
sınıfları ile müşteri türleri ve durumları liste halinde müşteri oluşturma formuna aktarılıp DropDownList
içerisinde gösterilecek. Böylelikle müşteri oluştururken kullanıcı bu değerlerden birini seçebilecek.
// Müşteri türlerinin veri modeli
public class CustomerTypeModel
{
public int Id { get; set; }
public string Value { get; set; }
// Veritabanından tek satır okuma işlemi
public void GetFromDataReader(SqlDataReader dataReader)
{
Id = Convert.ToInt32(dataReader["colCustomerTypeID"]);
Value = dataReader["colCustomerType"].ToString();
}
}
// Müşteri durumlarının veri modeli
public class CustomerStatusModel
{
public int Id { get; set; }
public string Value { get; set; }
// Veritabanından tek satır okuma işlemi
public void GetFromDataReader(SqlDataReader dataReader)
{
Id = Convert.ToInt32(dataReader["colCustomerStatusID"]);
Value = dataReader["colCustomerStatus"].ToString();
}
}
// İki veri türü aynı sayfada olacağı için tek bir veri türünde birleştirmek faydalı olacaktır
public class CustomerValuesModel
{
public List<CustomerTypeModel> CustomerTypes { get; set; }
public List<CustomerStatusModel> CustomerStatuses { get; set; }
public CustomerValuesModel() { CustomerTypes = new List<CustomerTypeModel>(); CustomerStatuses = new List<CustomerStatusModel>(); }
}
Controller Oluşturma
Controllers dizini içerisinde CustomerController
isimli bir MVC Controller oluşturun. İçerisinde oluşturacağımız Action metotları asenkronize olacaktır. Böylelikle program aynı anda birden fazla işlemi çalıştırabilir.
public class CustomerController : Controller
{
// Sayfa ilk açıldığında çalışacak metot budur
public async Task<ActionResult> Create()
{
DBHelper db = new DBHelper();
ViewBag.CustomerValues = await db.GetCustomerValues();
return View();
}
// Sayfadaki form doldurulup gönderildiğinde çalışacak metot budur
[HttpPost]
[ValidateAntiForgeryToken]
public async Task<ActionResult> Create(CustomerModel customer)
{
DBHelper db = new DBHelper();
ViewBag.CustomerValues = await db.GetCustomerValues();
var result = await db.CreateProcedure(customer);
if (result.Success) ModelState.Clear();
ViewBag.Result = result;
return View();
}
}
ValidateAntiForgeryToken
isimli attribute isteğin başka bir uygulamadan gönderilmesini engeller. View üzerindeki formda da @Html.ValidationSummary(true, "", new { @class = "text-danger" })
satırı sayesinde Action metodu ile üretilen token, web sayfasındaki token ile eşleştirilerek işlem yapılır.
Create ismine sağ tıklayıp Add View tuşuna basarak action metodu için View
ekleyebilirsiniz.
Herhangi bir model seçmeksizin ekleyebilir veya Empty seçeneği yerine Create seçeneği ile model olarak InvoicesWeb.Models.CustomerModel
veri türünü seçip de oluşturabilirsiniz.
@model InvoicesWeb.Models.CustomerModel
@{
ViewBag.Title = "Müşteri Oluştur";
InvoicesWeb.Models.CustomerValuesModel customerValues = ViewBag.CustomerValues;
List<SelectListItem> listCustomerTypes = new List<SelectListItem>();
foreach (var type in customerValues.CustomerTypes)
{
listCustomerTypes.Add(new SelectListItem() { Text = type.Value, Value = type.Id.ToString() });
}
List<SelectListItem> listCustomerStatuses = new List<SelectListItem>();
foreach (var type in customerValues.CustomerStatuses)
{
listCustomerStatuses.Add(new SelectListItem() { Text = type.Value, Value = type.Id.ToString() });
}
InvoicesWeb.Helpers.DBResult result = ViewBag.Result;
}
<h2>Müşteri Oluştur</h2>
@using (Html.BeginForm())
{
@Html.AntiForgeryToken()
<div class="form-horizontal">
<hr />
@Html.ValidationSummary(true, "", new { @class = "text-danger" })
<div class="form-group">
@Html.LabelFor(model => model.Name, htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.EditorFor(model => model.Name, new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model.Name, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(model => model.CustomerTypeId, htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.DropDownListFor(model => model.CustomerTypeId, listCustomerTypes, new { @class = "form-control" })
@Html.ValidationMessageFor(model => model.CustomerTypeId, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(model => model.CustomerStatusId, htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.DropDownListFor(model => model.CustomerStatusId, listCustomerStatuses, new { @class = "form-control" })
@Html.ValidationMessageFor(model => model.CustomerStatusId, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(model => model.Email, htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.EditorFor(model => model.Email, new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model.Email, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(model => model.Phone, htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.EditorFor(model => model.Phone, new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model.Phone, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(model => model.TaxNumber, htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.EditorFor(model => model.TaxNumber, new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model.TaxNumber, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(model => model.Address, htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.EditorFor(model => model.Address, new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model.Address, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
<div class="col-md-offset-2 col-md-10">
<input type="submit" value="Oluştur" class="btn btn-default" />
@if (result != null)
{
<span class="text-@(result.Success ? "success" : "danger")">@result.Result</span>
}
</div>
</div>
</div>
}
<div>
<a href="@Url.Action("List", "Customer")">Listeye Dön</a>
</div>
Müşteri oluşturmak için kullanılacak formun View
içeriği yukarıdaki gibidir. Ancak uygulamayı çalıştırıp http://localhost:xxxxx/Customer/Create
sayfasına girdiğinizde aşağıdaki gibi bir görüntü ile karşılaşacaksınız.
Formdaki @Html.LabelFor
metotları CustomerModel
nesnesinin doğrudan özellik adını getirecektir. Bunun yerine doğrudan label
tagı oluşturabilirsiniz. Veya @Html.LabelFor(model => model.Name, "Müşteri Adı", htmlAttributes: new { @class = "control-label col-md-2" })
şeklinde fazladan parametre ile görünmesini istediğiniz ismi yazabilirsiniz. Ya da CustomerModel
sınıfının özelliklerine Display
isminde bir attribute ekleyebilirsiniz.
public class CustomerModel: IProcedure
{
[Display(Name = "Müşteri Adı")]
public string Name { get; set; }
[Display(Name = "Müşteri Türü")]
public int CustomerTypeId { get; set; }
[Display(Name = "Müşteri Türü")]
public string CustomerType { get; private set; }
[Display(Name = "Müşteri Durumu")]
public int CustomerStatusId { get; set; }
[Display(Name = "Müşteri Durumu")]
public string CustomerStatus { get; private set; }
[Display(Name = "E-Posta")]
public string Email { get; set; }
[Display(Name = "Telefon")]
public string Phone { get; set; }
[Display(Name = "Vergi Numarası")]
public string TaxNumber { get; set; }
[Display(Name = "Adres")]
public string Address { get; set; }
public DateTime Register { get; set; }
// ...
}
CustomerModel
sınıfını yukarıdaki gibi güncellediğinizde görünen etiketler de değişecektir.
Formu doldurup Oluştur tuşuna tıkladığınızda form bilgileri CustomerController
içindeki [HttpPost]
olarak tanımlanan Create
metoduna gönderilecek. Aşağıdaki kodlar çalıştırılacaktır.
DBHelper db = new DBHelper();
// DBHelper nesnesi tanımlanır
ViewBag.CustomerValues = await db.GetCustomerValues();
// Müşteri durumları ve müşteri türleri dropdowna konulmak üzere veritabanından çekilir
var result = await db.CreateProcedure(customer);
// oluşturma prosedürü çalıştırılır
if (result.Success) ModelState.Clear();
// eğer oluşturma başarılı ise View' a ait model yani CustomerModel nesnesi temizlenir
// bu alanların temizlenmesini sağlar
ViewBag.Result = result;
// sonuç bilgisi ViewBag üzerinde Result dynamic değişkenine gönderilir
return View();
//View() metodu ile arayüz geri döndürülür
Form bilgileri gönderilip veritabanındaki prosedür çalıştırılınca girilen veriler tblCustomers
tablosuna satır olarak işlenecektir.
Tek bir müşteri kaydını okumak için aşağıdaki metodu CustomerModel
sınıfı içerisine ekleyin.
public class CustomerModel: IProcedure
{
// ...
public SqlCommand ToGetOneCommand(SqlConnection connection)
{
// SqlCommand ile tek bir müşteri kaydını almak için uygulanan sorgu
SqlCommand command = new SqlCommand(@"
select colCustomerID, colName, c.colCustomerTypeID, c.colCustomerStatusID,
colCustomerStatus, colCustomerType, colEmail, colPhone, colTaxNumber,
colAddress, colRegister
from tblCustomers c
left join tblCustomerTypes ct on ct.colCustomerTypeID = c.colCustomerTypeID
left join tblCustomerStatuses cs on cs.colCustomerStatusID = c.colCustomerStatusID
where colCustomerID = @_customerId", connection);
command.Parameters.Add(PrmCustomerId);
return command;
}
// ...
}
Bu metot sadece gereken SqlCommand
nesnesini oluşturacaktır. DBHelper
sınıfı içerisinde bu metodu çağıracağınız başka bir metot ekleyin.
public class DBHelper
{
// ...
// Tek bir müşteri kaydını almak için
public async Task<CustomerModel> GetCustomer(int id)
{
CustomerModel customer = new CustomerModel() { CustomerId = id };
var connection = await OpenConnection();
var command = customer.ToGetOneCommand(connection);
var dataReader = await command.ExecuteReaderAsync();
while (await dataReader.ReadAsync())
{
customer.GetFromDataReader(dataReader);
}
CloseConnection(connection);
return customer;
}
// ...
}
Controller içerisine aşağıdaki metotları da ekleyip diğer işlemleri tamamlayabilirsiniz.
public class CustomerController : Controller
{
public async Task<ActionResult> List()
{
DBHelper db = new DBHelper();
ViewBag.Customers = await db.ListCustomers();
return View();
}
public async Task<ActionResult> Create()
{
DBHelper db = new DBHelper();
ViewBag.CustomerValues = await db.GetCustomerValues();
return View();
}
[HttpPost]
[ValidateAntiForgeryToken]
public async Task<ActionResult> Create(CustomerModel customer)
{
DBHelper db = new DBHelper();
ViewBag.CustomerValues = await db.GetCustomerValues();
var result = await db.CreateProcedure(customer);
if (result.Success) ModelState.Clear();
ViewBag.Result = result;
return View();
}
public async Task<ActionResult> Edit(int id)
{
DBHelper db = new DBHelper();
var customer = await db.GetCustomer(id);
ViewBag.Customer = customer;
ViewBag.CustomerValues = await db.GetCustomerValues();
return View(customer);
}
[HttpPost]
public async Task<ActionResult> Edit(CustomerModel customer)
{
DBHelper db = new DBHelper();
ViewBag.CustomerValues = await db.GetCustomerValues();
var result = await db.UpdateProcedure(customer);
ViewBag.Result = result;
return View();
}
public async Task<ActionResult> Delete(int id)
{
DBHelper db = new DBHelper();
var customer = await db.GetCustomer(id);
if (customer == null) return RedirectToAction("List", "Customer");
ViewBag.CustomerName = customer.Name;
return View(customer);
}
[HttpPost, ActionName("Delete")]
public async Task<ActionResult> DeleteConfirm(int id)
{
DBHelper db = new DBHelper();
CustomerModel customer = new CustomerModel() { CustomerId = id };
var result = await db.DeleteProcedure(customer);
return RedirectToAction("List", "Customer");
}
}
Proje içerisinde CustomerController
' a ait Create
için View mevcut. Müşterileri listelemek için List
, düzenleme işlemleri için Edit
, silmek için ise Delete
metotlarına birer View oluşturmanız gerekiyor.
Create
metoduna oluşturduğunuz gibi bu metotlara da sağ tıklayıp View oluşturun. HttpPost
özelliği olan actionlar için view oluşturmayın. Edit.cshtml
Viewi aşağıdaki gibi olmalıdır.
@model InvoicesWeb.Models.CustomerModel
@{
ViewBag.Title = "Müşteri Düzenle";
InvoicesWeb.Models.CustomerValuesModel customerValues = ViewBag.CustomerValues;
List<SelectListItem> listCustomerTypes = new List<SelectListItem>();
foreach (var type in customerValues.CustomerTypes)
{
listCustomerTypes.Add(new SelectListItem() { Text = type.Value, Value = type.Id.ToString() });
}
List<SelectListItem> listCustomerStatuses = new List<SelectListItem>();
foreach (var type in customerValues.CustomerStatuses)
{
listCustomerStatuses.Add(new SelectListItem() { Text = type.Value, Value = type.Id.ToString() });
}
InvoicesWeb.Helpers.DBResult result = ViewBag.Result;
}
<h2>Müşteri Düzenle</h2>
@using (Html.BeginForm())
{
@Html.AntiForgeryToken()
<div class="form-horizontal">
@Html.HiddenFor(model => model.CustomerId)
<hr />
@Html.ValidationSummary(true, "", new { @class = "text-danger" })
<div class="form-group">
@Html.LabelFor(model => model.Name, htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.EditorFor(model => model.Name, new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model.Name, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(model => model.CustomerTypeId, htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.DropDownListFor(model => model.CustomerTypeId, listCustomerTypes, new { @class = "form-control" })
@Html.ValidationMessageFor(model => model.CustomerTypeId, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(model => model.CustomerStatusId, htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.DropDownListFor(model => model.CustomerStatusId, listCustomerStatuses, new { @class = "form-control" })
@Html.ValidationMessageFor(model => model.CustomerStatusId, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(model => model.Email, htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.EditorFor(model => model.Email, new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model.Email, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(model => model.Phone, htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.EditorFor(model => model.Phone, new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model.Phone, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(model => model.TaxNumber, htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.EditorFor(model => model.TaxNumber, new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model.TaxNumber, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
@Html.LabelFor(model => model.Address, htmlAttributes: new { @class = "control-label col-md-2" })
<div class="col-md-10">
@Html.EditorFor(model => model.Address, new { htmlAttributes = new { @class = "form-control" } })
@Html.ValidationMessageFor(model => model.Address, "", new { @class = "text-danger" })
</div>
</div>
<div class="form-group">
<div class="col-md-offset-2 col-md-10">
<input type="submit" value="Düzenle" class="btn btn-default" />
@if (result != null)
{
<span class="text-@(result.Success ? "success" : "danger")">@result.Result</span>
}
</div>
</div>
</div>
}
<div>
<a href="@Url.Action("List", "Customer")">Listeye Dön</a>
</div>
Delete.cshtml
isimli view ise aşağıdaki gibi olacaktır.
@model InvoicesWeb.Models.CustomerModel
@{
ViewBag.Title = "Müşteri Sil";
}
<h2>Müşteri Sil</h2>
<h3>Müşteri kaydını silmek istediğinize emin misiniz?</h3>
<div>
<hr />
<dl class="dl-horizontal">
<dt>
@Html.DisplayNameFor(model => model.Name)
</dt>
<dd>
@Html.DisplayFor(model => model.Name)
</dd>
<dt>
@Html.DisplayNameFor(model => model.CustomerType)
</dt>
<dd>
@Html.DisplayFor(model => model.CustomerType)
</dd>
<dt>
@Html.DisplayNameFor(model => model.CustomerStatus)
</dt>
<dd>
@Html.DisplayFor(model => model.CustomerStatus)
</dd>
<dt>
@Html.DisplayNameFor(model => model.Email)
</dt>
<dd>
@Html.DisplayFor(model => model.Email)
</dd>
<dt>
@Html.DisplayNameFor(model => model.Phone)
</dt>
<dd>
@Html.DisplayFor(model => model.Phone)
</dd>
<dt>
@Html.DisplayNameFor(model => model.TaxNumber)
</dt>
<dd>
@Html.DisplayFor(model => model.TaxNumber)
</dd>
<dt>
@Html.DisplayNameFor(model => model.Address)
</dt>
<dd>
@Html.DisplayFor(model => model.Address)
</dd>
<dt>
@Html.DisplayNameFor(model => model.Register)
</dt>
<dd>
@Html.DisplayFor(model => model.Register)
</dd>
</dl>
@using (Html.BeginForm()) {
@Html.AntiForgeryToken()
<div class="form-actions no-color">
<input type="submit" value="Sil" class="btn btn-default" /> |
@Html.ActionLink("Listeye Dön", "List", "Customer")
</div>
}
</div>
İlişkili İçerikler
Fatura kayıtlarının içerisinde tutulacağı ve işleneceği veritabanını MS-SQL üzerinde oluşturabilirsiniz.
ASP.NET MVC ile fatura kayıtlarının tutulduğu, görüntülendiği, güncellendiği bir uygulama oluşturabilirsiniz.
Oturum açmak için sayfa düzenini belirlemek, gönderilen oturum bilgilerinin veritabanında prosedür ile doğrulanması ve yönlendirme işlemleri login sayfasının temel işleyişidir.
Fatura Kayıtları projesinde faturalar ve fatura satırları için de birer controller oluşturup gereken metotları oluşturabilirsiniz.