Model負責獲取數據庫中的資料,並對數據庫中的數據進行處理。

MVC中有關 數據庫 的任務都由Model來完成,Model中對數據資料進行定義,Controller和View中都會參考到Model,從而對數據庫進行增刪改的操作。

    

Model不需要依賴Controller或是View,所以Model的獨立性很高,我們可以把Model獨立出來一個專案。

1,Model中添加實體數據模型

DB中添加新的DataBase:message,添加Table:MessageBoard

USE [message]
GO
/****** Object: Table [dbo].[MessageBoard] Script Date: 08/25/2014 09:42:13 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE TABLE [dbo].[MessageBoard](
[ID] [int] IDENTITY(,) NOT NULL,
[msg_name] [nvarchar]() NOT NULL,
[msg_Content] [nvarchar](max) NOT NULL,
CONSTRAINT [PK_MessageBoard] PRIMARY KEY CLUSTERED
(
[ID] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]

新建MVC專案,並從數據庫中添加新的ADO.NET實體數據模型:

        

   

2,添加Service類實現對MessageBoard的CUDR

快捷鍵:Ctrl+M,O折疊代碼定義  Ctrl+M,L展開代碼定義  Ctrl+K,S添加外側代碼

新建Service文件夾並添加類:

類中實現對MessageBoard的增刪改查:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using MvcApplication2.Models; namespace MvcApplication2.Service
{
public class messageDBService
{
//實例化實體數據
MessageEntities database = new MessageEntities(); #region Create Function
//Create方法,參數是 name 和 content
public void Create(string name, string content)
{
//實例化 一條數據
MessageBoard NewMsg = new MessageBoard(); NewMsg.msg_name = name;
NewMsg.msg_Content = content; //實例化對象添加到 database中
database.MessageBoards.Add(NewMsg);
//儲存
database.SaveChanges();
} //Create 方法重載,參數是 MessageBoard類型的記錄
public void Create(MessageBoard NewMsg)
{
//實例化對象添加到 database中
database.MessageBoards.Add(NewMsg);
//儲存
database.SaveChanges();
}
#endregion #region Update Function
//update ,參數是傳遞過來的id,name,content
public bool Update(int id, string name, string content)
{
//檢查id對應的記錄是否存在
MessageBoard msg = database.MessageBoards.Find(id);
if (msg != null)
{
msg.msg_name = name;
msg.msg_Content = content;
database.SaveChanges(); return true;
}
else
{
return false;
}
}
//update ,參數是 MessageBoard
public bool Update(MessageBoard msgUpd)
{
//檢查id對應的記錄是否存在
MessageBoard msg = database.MessageBoards.Find(msgUpd.ID);
if (msg != null)
{
msg.msg_name = msgUpd.msg_name;
msg.msg_Content = msgUpd.msg_Content;
database.SaveChanges(); return true;
}
else
{
return false;
}
}
#endregion #region Delete Function
public bool Delete(int id)
{
MessageBoard msgDel = database.MessageBoards.Find(id);
if (msgDel != null)
{
//Delete
database.MessageBoards.Remove(msgDel); return true;
}
else
{
return false;
}
}
#endregion #region Query Funcion
//返回所有message
public List<MessageBoard> GetList()
{
List<MessageBoard> msgList = database.MessageBoards.ToList();
return msgList;
}
//一條記錄
public MessageBoard getMessage(int id)
{
MessageBoard msg = database.MessageBoards.Find(id);
return msg;
} #endregion } }

以上我們看到了Model的作用:把數據通過Entity從數據庫中拉過來,新增類實現對數據的處理

3,Model-Controller-View之間關係的建立

1,Controller中新增messageController

2,新增ViewModel文件夾,並添加IndexViewModel.cs文件

3,Ctrl+Shit+B重建解決方案以後,messageController中右鍵點擊Index()添加View,我們選擇IndexViewModel

4,這樣M-V-C之間的關係就出來了:M(indexViewModel)—V(index.cshtml)—C(messageController)

4,ViewMode介紹

ViewModel從字面上看就是給View用的Model.

View頁面最上面的引用如下,只能引用一個Model,但是View頁面的屬性中往往會用到多張Table中的字段屬性。

所以我們建立View對應的Model,命名為ViewModel,把需要的屬性都整合在一起供View使用。

@model MvcApplication2.ViewModels.IndexViewModel

ViewModel包含的內容:

  • 定義View所需要的字段屬性
  • 包含屬性的驗證規則
  • 可以有多個不同的資料庫實體組合
  • 定義顯示模板(DisplayFor,EditFor,LabelFor)的介面樣式

Model Validate

      ViewModel中對從View傳遞過來的字段的值 可以按照一定的規則進行驗證其是否符合規範,例如是否是正確的郵箱地址

常用的驗證如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.ComponentModel;
using System.ComponentModel.DataAnnotations; namespace MvcApplication2.ViewModels
{
public class IndexViewModel
{
//1,[DisplayName] View中顯示Title屬性對應的名稱為必修課
[DisplayName("必修课")]
public string Title { get; set; } //2,[Required] Name字段不能為空,如果為空將提示ErrorMessage
[Required(ErrorMessage = "學生姓名必須填寫")]
public string Name { get; set; } //3,[StringLength] 定義字符串的長度,ErrorMessage顯示不符合長度的錯誤信息
[StringLength(, ErrorMessage = "長度必須在2-10個字符之間", MinimumLength = )]
public string Course { get; set; } //4,[Range]定義數值範圍
[Range(, , ErrorMessage = "分數必須在0-100之間")]
public int Score { get; set; } //5, [Compare]和另外的一個字段比較是否一直
[Compare("re_password", ErrorMessage = "兩次密碼輸入不一致")]
public string password { get; set; }
public string re_password { get; set; } //6,[RegularExpression] 更具正則表達式進行驗證
[RegularExpression(@"^(\d{3,4}-)?\d{7,8})$|(13[0-9]{9}", ErrorMessage = "請輸入正確的手機號碼")] //:(^(\d{3,4}-)?\d{7,8})$|(13[0-9]{9})
public string Phone { get; set; } //7,[EmailAddress] Email格式驗證
[EmailAddress(ErrorMessage = "請填寫正確的Email格式")]
public string StuMail { get; set; } //8,[Url] 網址驗證
[Url(ErrorMessage = "網址格式錯誤")]
public string url { get; set; } //[FileExtensions] 文件格式檢查,預設格式:.png,.jpg,.jpeg,.gif
[FileExtensions(ErrorMessage = "上傳文件格式錯誤")]
public string file { get; set; } //[CreditCard] 信用卡卡號檢查
[CreditCard(ErrorMessage = "信用卡格式錯誤")]
public string creditCard { get; set; } //[DataType] 字段類型檢查
[DataType(DataType.Date)]
public DateTime date { get; set; } }
}

ASP.NET MVC 4.0 学习3-Model的更多相关文章

  1. ASP.NET MVC 4.0 学习5-ActionResult

    一,Controller簡介 Controller擔任了資料傳遞的角色,負責流程控制,決定存取哪個Model以及決定顯示哪個View頁面,即ASP.NET MVC中有關於『傳遞』的任務皆由Contro ...

  2. ASP.NET MVC 4.0 学习6-Model Binding

    一,ViewData,ViewBag與TempData ASP.NET MVC架構中,通過繼承在Controller中的ViewData,ViewBag和TempData和View頁面進行資料的存取, ...

  3. ASP.NET MVC 4.0 学习2-留言板實現

    新增專案實現留言板功能,瞭解MVC的運行機制 1,新增專案   2,添加數據庫文件message.mdf   Ctrl+W,L 打開資料庫連接,添加存放留言的Atricle表 添加字段,後點擊&quo ...

  4. ASP.NET MVC 4.0 学习1-C#基础语法

    1,方法多載,相同的方法名稱,不同的參數類型.數量 class Program { static void Main(string[] args) { Program newObject = new ...

  5. ASP.NET MVC 4.0 学习4-Code First

    之前我們需要用到的數據,通過添加Entity實體數據模型把數據庫中需要的Database拉到項目中如下圖, 而就是Code First就是相對於這種處理數據的方法而言的 Code First更加準確的 ...

  6. 系列文章--从零开始学习ASP.NET MVC 1.0

    从零开始学习ASP.NET MVC 1.0 (一) 开天辟地入门篇 从零开始学习 ASP.NET MVC 1.0 (二) 识别URL的Routing组件 从零开始学习 ASP.NET MVC 1.0 ...

  7. 从零开始学习ASP.NET MVC 1.0

    转自:http://www.cnblogs.com/zhangziqiu/archive/2009/02/27/ASPNET-MVC-1.html <从零开始学习ASP.NET MVC 1.0& ...

  8. 返璞归真 asp.net mvc (8) - asp.net mvc 3.0 新特性之 Model

    原文:返璞归真 asp.net mvc (8) - asp.net mvc 3.0 新特性之 Model [索引页][源码下载] 返璞归真 asp.net mvc (8) - asp.net mvc ...

  9. 2.第一个ASP.NET MVC 5.0应用程序

    大家好,上一篇对ASP.NET MVC 有了一个基本的认识之后,这一篇,我们来看下怎么从头到尾创建一个ASP.NET MVC 应用程序吧.[PS:返回上一篇文章:1.开始学习ASP.NET MVC] ...

随机推荐

  1. 前端面试题之js篇

    前端面试也可为是鱼龙混杂,各公司面试题的种类也大不相同,有的公司注重基础语法,面试题偏于ES,有的公司偏于页面逻辑,会考差一些js的应用,现将遇到过的题和典型的题整理一下. 1. 0.2-0.1 == ...

  2. 行为级和RTL级的区别(转)

    转自:http://hi.baidu.com/renmeman/item/5bd83496e3fc816bf14215db RTL级,registertransferlevel,指的是用寄存器这一级别 ...

  3. 迁移笔记:php缓存技术memcached

    1)memcached 的几个指令: -p监听的端口 -l连接的IP地址, 默认是本机 -d start启动memcached服务 -d restart重起memcached服务 -d stop|sh ...

  4. Effective Java提升Code Coverage代码涵盖率 - 就是爱Java

    虽然我们已经有了测试程序,但是如何得知是否已完整测试了主程序?,透过Code Coverage代码涵盖率,我们可以快速地得知,目前系统中,有多少程序中被测试过,不考虑成本跟投资效益比,涵盖率越高,代表 ...

  5. mysql 的 decimal类型

    最近做项目时将decimal定义成了decimal(5,2),然后等到最大的结果都是999.99,找了很多地方找不出bug在哪里插入很更新的数据都是正确的而结果却都是999.99,最后才知道decim ...

  6. 开发人员应该知道的SEO

    搜索引擎是如何工作的 > 如果你有时间,可以读一下谷歌的框架: http://infolab.stanford.edu/~backrub/google.html > 这是一个老的,有些过时 ...

  7. IOS 监听通讯录是否改变

    ABAddressBookRef addressBook = ABAddressBookCreateWithOptions(NULL, &error); ABAddressBookRegist ...

  8. mycat实例(2)

    全局序列号 数据切分后,原有的关系数据库中的主键约束在分布式条件下将无法使用,因此需要引入外部机制保证数据唯一性标识,这种保证全局性的数据唯一标识的机制就是全局序列号(sequence). 1. 本地 ...

  9. SQUEEZENET: ALEXNET-LEVEL ACCURACY WITH 50X FEWER PARAMETERS AND <0.5MB MODEL SIZE

    论文阅读笔记 转载请注明出处: http://www.cnblogs.com/sysuzyq/p/6186518.html By 少侠阿朱

  10. Kafka的Producer以及Consumer远程调用问题

    公司需要分布式的JMS,所以研究了Kafka,之前在本地都没有出现问题,但是在服务器上布Kafka的时候发现了消费者无法消费的问题. kafka布到一台服务器上面,由于业务原因,producer和ka ...