这里面之所以没有Sql语句但是也可以对数据库进行数据操作的原因就是Entity Framework。Entity Framework有三种模式,这里用的是Models模式。

  网上有太多的.net MVC教程了,我就直接写一个我喜欢的版本得了。

先新建一个Models,起名为Movie.cs

using System;
using System.Collections.Generic;
using System.Data.Entity;
using System.Linq;
using System.Web; namespace Mvc.Models
{
public class Movie
{
public int ID { get; set; } //电影ID
public string Title { get; set; } //电影标题
public DateTime ReleaseDate { get; set; } //电影上映时间
public string Genre { get; set; } //电影类型
public decimal Price { get; set; } //电影票价格 } public class MovieDBContext : DbContext
{
public DbSet<Movie> Movies { get; set; } //DbSet是类型设置的意思
} }

这个Movie类里面的代码还是很好理解的吧,下面那个DbSet就是类型设置的意思,就是Movies是Movie类型的。ok,写完这个Model类之后,我们开始写controller,新建一个controller,命名为MovieController,但是步骤跟我来:

高级选项里这样,那个母版页你们自己加不加都行:

OK,加完这个Movie的controller之后,你看看Views文件夹是不是多了好多个View,现在其实就可以运行了,不过我们还要加一个数据库,在web.config里面这样写:

 <connectionStrings>
<add name="MovieDBContext" providerName="System.Data.SqlClient" connectionString="Server=KTY;Database=shuyunquan;Uid=sa;Pwd=123456"/>
</connectionStrings>

这样写就行了,至于数据库的一些操作语句就不劳你费心了,已经全部封装好了.....

现在来运行:

在地址栏里面输入Movie,然后你就可以进行些许操作了....

现在,我突然想搜索,我想搜数据了,先来一个简单的,直接在url框进行搜索

把MovieController里面的Index方法修改成这样:

 public ActionResult Index(string search)
{
var movies = from m in db.Movies select m;
if (!String.IsNullOrEmpty(search))
{
movies = movies.Where(s => s.Title.Contains(search));
} return View(movies);
}

其他的地方都不需要修改,我来讲讲这代码是什么意思。

Index方法带了一个参数,就是我想搜的东西的名字呗,下面的是一个LinQ语句,这个就当做sql sever语句来理解,就是把db.Movies里面的数据(等同于数据库里面的数据)全部取出来,给movies。然后下一个就是判断你输入的参数是不是空的,不是空或者NUll的话就执行语句,这个语句的意思呢其实就是Sql server查询的意思,这用到了lambda表达式,其实这一条语句等同于movies=select * from Movies where %search%

  最后,返回那里改一下返回值。其他地方不需要修改什么,我们直接运行,然后自己新建几条数据方便查找:

我新建了三条数据,现在来查找:

我查了一下许嵩,就出来了第一条,这个只要是包含了“许嵩”字符的都可以。ok完成了。下面来个高级一点的啦~~

------------------------------------------------------我是高级内容-----------------------------------------------------

还是查询,不过呢,这次我要搞一个UI出来,我要根据类别和标题两部分来查询

MovieController里面的Index方法这样写:

public ActionResult Index(string movieGenre,string search)
{
var GenreList = new List<string>(); //定义一个list数组
var GenreQry = from d in db.Movies orderby d.Genre select d.Genre;//定义一个变量存放Genre值
GenreList.AddRange(GenreQry.Distinct()); //存到数组里面
ViewBag.movieGenre = new SelectList(GenreList); //存到viewBag里面传给view界面 var movies = from m in db.Movies select m;
if (!String.IsNullOrEmpty(search))
{
movies = movies.Where(s => s.Title.Contains(search));
}
if (!String.IsNullOrEmpty(movieGenre))
{
movies = movies.Where(x => x.Genre == movieGenre);
} return View(movies);
}

添加了一些代码,在注释里面解释的差不多了,不过这里我有一个东东不明白,为什么GenreQry这个变量可以存这么多东西???

  我们在Index.cshtml里面呢添加几个UI来

<p>
@Html.ActionLink("Create New", "Create")
@using (Html.BeginForm()) //搞了一个表单
{
<p>
Genre:@Html.DropDownList("movieGenre", "All") //下拉列表选择
Title:@Html.TextBox("search") //textbox
<input type="submit" value="搜索" /> //搜索button
</p>
} </p>

  然后来预览一下吧,ctrl+shift+b编译,然后浏览器界面ctrl+F5刷新:

诺,想怎么筛选怎么筛选~

最后....真的是最后...来加一个校验机制吧~熊孩子或者熊大人不听话,偏偏新建的时候不按照格式来怎么办?多半是装的,打一顿就好了~咳咳~~当然是要加一个校验机制,来判断人输入的对不对,修改我们的Movie类:

using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations; //添加这个引用
using System.Data.Entity;
using System.Linq;
using System.Web; namespace Mvc.Models
{
public class Movie
{
public int ID { get; set; } //电影ID
[StringLength(,MinimumLength=)] //这就是校验机制
public string Title { get; set; } //电影标题
public DateTime ReleaseDate { get; set; } //电影上映时间
[StringLength()]
public string Genre { get; set; } //电影类型
[Range(,)]
[DataType(DataType.Currency)] //类型是货币类型
public decimal Price { get; set; } //电影票价格 } public class MovieDBContext : DbContext
{
public DbSet<Movie> Movies { get; set; }
} }

就是大概这样的格式,但是这个例子我运行不成功,暂时不知道原因,暂留。

.net MVC入门的更多相关文章

  1. 25、ASP.NET MVC入门到精通——Spring.net-业务层仓储

    本系列目录:ASP.NET MVC4入门到精通系列目录汇总 上一节,我们已经把项目框架的雏形搭建好了,那么现在我来开始业务实现,在业务实现的过程当中,不断的来完善我们现有的框架. 1.假设我们来做一个 ...

  2. 26、ASP.NET MVC入门到精通——后台管理区域及分离、Js压缩、css、jquery扩展

    本系列目录:ASP.NET MVC4入门到精通系列目录汇总 有好一段时间没更新博文了,最近在忙两件事:1.看书,学习中...2.为公司年会节目做准备,由于许久没有练习双截棍了,难免生疏,所以现在临时抱 ...

  3. asp.net mvc 入门资料

    七天学会ASP.NET MVC (一)——深入理解ASP.NET MVC http://www.cnblogs.com/powertoolsteam/p/MVC_one.html 无废话MVC入门教程 ...

  4. ASP.NET MVC 入门8、ModelState与数据验证

    原帖地址:http://www.cnblogs.com/QLeelulu/archive/2008/10/08/1305962.html ViewData有一个ModelState的属性,这是一个类型 ...

  5. ASP.NET MVC 入门系列教程

    ASP.NET MVC 入门系列教程 博客园ASP.NET MVC 技术专题 http://kb.cnblogs.com/zt/mvc/ 一个居于ASP.NET MVC Beta的系列入门文章,有朋友 ...

  6. Spring MVC 入门教程示例 (一)

    今天和大家分享下  Spring MVC  入门教程 首先还是从 HelloWorld  web 工程开始 -------------------------- 1.首先创建一个Maven Web工程 ...

  7. Asp.net MVC入门视频教程

    编程开发 > Asp.net视频教程 > Asp.net MVC入门视频教程 > 1.传统web处理方式和mvc处理方式 上传日期:2014-08-16 10:02:45  相关摘要 ...

  8. [转]ASP.NET MVC 入门8、ModelState与数据验证

    ViewData有一个ModelState的属性,这是一个类型为ModelStateDictionary的ModelState类型的字典集合.在进行数据验证的时候这个属性是比较有用的.在使用Html. ...

  9. 005.Getting started with ASP.NET Core MVC and Visual Studio -- 【VS开发asp.net core mvc 入门】

    Getting started with ASP.NET Core MVC and Visual Studio VS开发asp.net core mvc 入门 2017-3-7 2 分钟阅读时长 本文 ...

  10. MVC入门教程

    MVC入门系列教程-视频版本,已入驻51CTO学院,文本+视频学效果更好哦.视频链接地址如下: 点我查看视频.另外,针对该系列教程博主提供有偿技术支持,群号:226090960,群内会针对该教程的问题 ...

随机推荐

  1. jqGrid 列内容超过一定长度省略表示

    jqgrid初始化方法中的,对应列添加formatter方法 colNames : [ "描述" ], colModel : [ { name : 'description', i ...

  2. ECC检验与纠错

    引入ECC ECC:Error Checking and Correction,是一种差错检测和修正的算法. NAND闪存在生产和使用中都会有坏块产生,BBM就是坏块的管理机制.而生产坏块已经无法避免 ...

  3. Flume的简单理解

    由于没具体研究过画图,以前在公司每天都用Excel,所以很多图画都是画在了Excel上再剪切的,看着可能不太舒服. 先来看一下数据走向: 这样我们就大致了解了flume是干嘛的,在什么位置了. Flu ...

  4. idea使用actiBPM插件中文乱码

    idea 安转activiti插件后,编辑流程图发现保存后中文乱码,并且idea的字符集(Settings—>Editor—>File Encodings)已经设置为UTF-8,流程图中中 ...

  5. PHP 观察者模式和php实现 Observer Pattern

    观察者模式: 观察者模式(Observer Pattern):定义对象间的一种一对多依赖关系,使得每当一个对象状态发生改变时,其相关依赖对象皆得到通知并被自动更新.观察者模式又叫做发布-订阅(Publ ...

  6. Android webview背景设置为透明无效 拖动时背景闪烁黑色

    Adndroid 2.X的设置 webview是一个使用方便.功能强大的控件,但由于webview的背景颜色默认是白色,在一些场合下会显得很突兀(比如背景是黑色). 此时就想到了要把webview的背 ...

  7. centos7 设置静态IP

    centos7 设置静态IP 一.查找配置文件(/etc/sysconfig/network-scripts) [root@bogon network-scripts]# ll 总用量 232 -rw ...

  8. java实验报告三

    实验三 敏捷开发与XP实践 一.实验内容 1. XP基础 2. XP核心实践 3. 相关工具 二.实验步骤 (一)敏捷开发与XP 软件工程是把系统的.有序的.可量化的方法应用到软件的开发.运营和维护上 ...

  9. java实验报告五

    一.实验内容 1.掌握Socket程序的编写: 2.掌握密码技术的使用: 3.设计安全传输系统. 二.实验基础: IP和端口:IP是用来标示计算机,而端口是用来标示某个计算机上面的特定应用.至于它们的 ...

  10. Linux内核第一节

    存储程序计算机工作模型 存储程序计算机——冯诺依曼体系结构 IP:寄存器,总是指向内存的代码段.IP(16位) 32位(EIP) 64位(RIP). 内存:保存数据和指令. CPU:CPU从IP指向的 ...