[入门级] 基于 visual studio 2010 mvc4 的图书管理系统开发初步 (二)
[入门级] 基于 visual studio 2010 mvc4 的图书管理系统开发初步 (二)
相关资源
任务简介
开发工具:VS2010 项目框架:MVC4 浏览器:Chrome 数据库ORM框架:iBatis.net 数据库:mysql 后端开发语言:c# 前端开发语言:js,html5,css3 功能需求:1. 帐号登入验证 2. 书籍信息录入 3. 书籍信息查询,列表展示 4. 书籍信息更新修改 项目管理:git
MVC4开发基本介绍
见上一篇文章:visual studio 2010 mvc4开发,用ibatis作为数据库访问媒介(一)。
git版本控制基本介绍
版本控制采用git,在visual studio上使用git可以参考:blog.csdn.net/leichelle/article/details/8002636
关于git操作的详细内容可以参见:廖雪峰的官方网站
常见的git操作
创建版本库
git init
设定版本库不关心的文件
新建 .gitignore 然后在文件中添加不需要的文件格式,如 *.exe
将文件放到版本库门口
git add file.txt or git add *.txt or git add ./ # 添加当前目录下的所有文件
查看当前版本库的状态
git status # 能够看到,哪些东西离版本库的门口还很远,哪些东西已经放到了版本库的门口
将放在版本库门口的文件,送到版本库里面
git commit -m "add file.txt" # 引号中的内容,用来说明,这一次你将哪些东西,从门口放到了内部
比较修改的文件和原来放在版本库中的文件有什么区别
git diff file.txt
查看版本库中已经放了多少个版本
git log --pretty=oneline # 其中很长的一串数据表示commit id
退回到上个的版本
git reset --hard HEAD^
退回到特定版本
git reset --hard 3628164 # 如果忘记了版本号,可以通过git reflog查看
ibatis设定
建立与图书管理系统相关的数据库,以及数据表,并且设定ibatis相关的config文件,数据操作映射的xml文件等。
数据库以及表的建立如下,同时插入示例数据:
create database if not exists `bookmanagementsystem`; create table if not exists `BOOK` (
`BK_ID` bigint not null auto_increment,
`BK_TITLE` varchar(255) not null,
`BK_AUTHOR` varchar(100) not null,
`BK_IS_READED` bool not null default false,
`BK_PUBLISHER` varchar(255) not null,
`BK_PUBLISH_TIME` datetime not null,
`BK_DESCRIPTION` text not null,
`BK_ISBN` varchar(100) not null,
`BK_PRICE` decimal not null,
primary key(BK_ID)
); # second insert example elements insert into `BOOK` (
`BK_TITLE`, # 书籍的标题
`BK_AUTHOR`, # 书籍的作者
`BK_PUBLISHER`, # 书籍的出版社
`BK_PUBLISH_TIME`, # 书籍出版时间
`BK_DESCRIPTION`, # 书籍简介
`BK_ISBN`, # 书籍ISBN号
`BK_PRICE`, # 书籍的价格
)
values (
"中国古代文学作品选简编",
"袁世硕",
"中国人民大学出版社",
"2015-01-01",
"本书是为配合中国文学史课的敎学,按照歷史的顺序,选注自先秦至二十世纪五四新文学运动发生,歷代主要文体的优秀作品二百多家近千篇。入选篇目以经过歷史选择的传世之作为主,注意突出在文学史上占有重要地位的作家的代表作,兼顾到不同的流派、风格,以便与中国文学史的敎材相呼应,体现出中国古代文学及其演变的风貌。第一版畅销多年,此次修订根据使用师生意见,增加了古代小说选篇,以使作品门类更加完整。",
"978-7-300-20262-4",
98.00
),(
"骨与关节影像学",
"陈克敏,陆勇",
"上海科学技术出版社",
"2015-01-01",
"本书由我国骨放射学领域的著名专家和中靑年专家在总结自身实践经验和近年来新进展的基础上编写而成。本书囊括了几乎所有骨骼肌肉疾病的影像学知识,配有2000余幅黑白照片,重点论述各种骨骼肌肉疾病的病理、X线、CT、MRI、造影等综合影像的诊断和鉴别诊断。本书以近10年影像诊断的进展为主,也有多年积累的少见骨骼肌肉疾病的珍贵资料,图文并茂,可为国内医学影像硏究、敎学及培训中靑年影像医务人员提供全面系统的资料,供放射科、骨科及其他临床科室医务人员参考。",
"978-7-5478-2309-5",
248.00
);
起步
建立新mvc4项目,命名为BookMS,选择Internet Application模版,并勾选添加Unit test选项。然后,将相应的ibatis配置文件设置好,然后将解决方案中的所有内容添加到git项目中,git commit -m "initial project"
,其中obj文件夹并不包含在git项目中,即,在.gitignore文件中添加obj
,如果还有其他额外的文件不需要包含到项目中,添加到.gitignore文件即可。
Model建立
默认的模版中在Models文件夹下会有AccountModels.cs,但是我们这里暂时不考虑关于 用户登入管理相关内容,于是,在此略过。 在后续文章中会介绍相关的内容。
建立对应的Book.cs用来和数据表中的字段对应,即,数据模型。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.ComponentModel.DataAnnotations; namespace BookMS.Models
{
public class Book
{
public int Id { get; set; } [Required(ErrorMessage="Title is required")]
[StringLength()]
public string Title { get; set; } [Required(ErrorMessage = "Title is required")]
[StringLength()]
public string Author { get; set; } [Required]
public bool IsReaded { get; set; } [Required(ErrorMessage = "Publisher is required")]
[StringLength()]
public string Publisher { get; set; } [Required(ErrorMessage = "Publish Time is required")]
public DateTime PublishTime { get; set; } [Required(ErrorMessage = "Description is required")]
public string Description { get; set; } [Required(ErrorMessage = "ISBN is required")]
[StringLength()]
public string ISBN { get; set; } [Required(ErrorMessage = "Price is required")]
[DataType(DataType.Currency)]
public decimal Price { get; set; }
}
}
控制器(Controller)创建
命名为BooksController.cs。根据最初的功能需求可知,需要完成的有:1. 帐号登入验证 2. 书籍信息录入 3. 书籍信息查询,列表展示 4. 书籍信息更新修改
除了第一项是和帐号登入相关,其他几项都是和书籍相关的,也就是需要两个控制器。一个是 AccountController.cs,另一个是BooksController.cs。
关于帐号登入验证的内容将在后续文章中介绍
从需求中知,BooksController控制器中的方法,需要有:
- Create [get|post] 书籍信息录入
- SearchList [get] 书籍信息查询,以及列表展示
- List [get] 书籍信息列表展示
- Edit [get|post] 书籍信息更新修改
- Details [get] 查看书籍信息详细内容
- Delete [get|post] 删除书籍信息
我是一个新手,所以一开始在具体实现的时候,最容易选择的方式是,直接在相应的控制器的action中对数据库进行操作。
首先添加List action, 注意添加引用:using IBatisNet.DataMapper; using BookMS.Models;。
public ActionResult List()
{
IList<Book> books = Mapper.Instance().QueryForList<Book>(
"Book.BKSelectAll", null);
return View(books);
}
其中BKSelectAll
,表示的是Book.xml中与数据库操作相对应的标示符。 注意:BKSelectAll前面的sqlMap的Book表示命名空间,因为在SqlMap.config中将useStateNamespace设置成了true
<!-- in Book.xml -->
<select id="BKSelectAll" resultMap="BKSelectResult">
select * from BOOK
</select>
对应的View视图很容易实现,先将项目build一下,然后右键添加View,选择Create a strongly-type view,并选择model class为Book,scaffold template选择为list,确认即可。
运行后输出的结果如下:
接着添加,create action
[HttpGet]
public ActionResult Create()
{
return View();
} [HttpPost]
public ActionResult Create(Book book)
{
if (ModelState.IsValid)
{
Mapper.Instance().Insert("Book.BKInsert", book);
return RedirectToAction("List");
} ModelState.AddModelError("", "创建图书信息出现错误");
return View();
}
添加delete action,edit action,detail action,具体的代码就不再下面给出了,可以直接从 源代码附件中查看。另外,对应的view可以分别借助scaffold template中的create,delete,edit,detail建立。
最后一个功能就是书籍信息的查询,在List视图中,添加两个用于输入查找信息的输入框,这里设定能够通过书名(Title)和作者名(Author)查询书籍信息,即:
<!-- in List.cshtml -->
<p>
@Html.ActionLink("Create New", "Create")
</p>
@using (Html.BeginForm("SearchList", "Books", FormMethod.Get))
{
<p>
Title: @Html.TextBox("sTitle")
Author: @Html.TextBox("sAuthor")
<input type="submit" value="Search" />
</p>
}
另外在BooksController中添加SearchList control,并且修改List control,如下:
public ActionResult List(IList<Book> books = null)
{
if (books == null)
books = Mapper.Instance().QueryForList<Book>("Book.BKSelectAll", null);
return View(books);
} public ActionResult SearchList(string sTitle, string sAuthor)
{
IList<Book> books = Mapper.Instance().QueryForList<Book>("Book.BKSelectByTitleAuthor",
new Book { Title = "+sTitle+", Author = "+sAuthor+" });
return View("List", books);
}
其中,BKSelectByTitleAuthor对应的statement为:
<select id="BKSelectByTitleAuthor" resultMap="BKSelectResult" parametersClass="Book">
select * from BOOK where
BK_TITLE like #Title# and
BK_AUTHOR like #Author#
</select>
至此,拥有最基本功能(不含有用户帐号控制的),同时也是非常粗略的图书管理系统就此完成了,为了在运行后的网页能够直接调转到:Books/List。需要在HomeController.cs中的Index方法内,将View()
改为:RedirectToAction("List", "Books")
。
下一篇预告
对建立的《图书管理系统》尝试进行如下优化:
- 数据库优化
- 代码优化
- 建立单元测试
[入门级] 基于 visual studio 2010 mvc4 的图书管理系统开发初步 (二)的更多相关文章
- [转]基于Visual Studio 2010 进行敏捷/Scrum模式开发
http://www.infoq.com/cn/articles/visual-studio-2010-agile-scrum-development 根据Forrester Research今年第二 ...
- [入门级] visual studio 2010 mvc4开发,用ibatis作为数据库访问媒介(一)
[入门级] visual studio 2010 mvc4开发,用ibatis作为数据库访问媒介(一) Date 周二 06 一月 2015 By 钟谢伟 Tags mvc4 / asp.net 示 ...
- 基于Visual Studio 2010 阐述C#4个特性
Csharp4.0与以往版本基础体现了强大的性能优势,主要体现在以下四个方面: 1. 通过委托成员来实现接口 在C# 4.0中可以通过委托来实现某个成员的接口,例如下面的代码: public clas ...
- 原创:基于visual studio 2010 对话框程序的创建
1)创建工程 2)选择对话框应用 3)打开工具箱 先打开资源管理器,点击IDD_TEST1_DIALOG对话框,然后在菜单栏中“视图”----“工具箱”
- Visual Studio 2010 中的 Web 开发
概述 Microsoft Visual Studio 2010 为 ASP.NET Web 应用程序的开发提供非常多新的功能.这些新功能旨在帮助开发者高速方便地创建和部署质量高且功能全的 Web 应用 ...
- 提高你开发效率的十五个Visual Studio 2010使用技巧
提高你开发效率的十五个Visual Studio 2010使用技巧 相信做开发的没有不重视效率的.开发C#,VB的都知道,我们很依赖VS,或者说,我们很感谢VS.能够对一个IDE产生依赖,说明这个ID ...
- 用C#语言在Visual Studio 2010里开发一个自定义的PowerShell Cmdlet
1. 打开Visual Studio 2010 2. 新建一个基于Class Library的项目 3. 给项目起个名字然后OK 4. 为项目添加下列Reference System.Manageme ...
- WIN7环境下CUDA7.5的安装、配置和测试(Visual Studio 2010)
以下基于"WIN7(64位)+Visual Studio 2010+CUDA7.5". 系统:WIN7,64位 开发平台:Visual Studio 2010 显卡:NVIDIA ...
- Windows下使用Visual Studio 2010编译ffmpeg全过程
在visual studio 2010中调用ffmpeg http://blog.sina.com.cn/s/blog_4178f4bf01018wqh.html Windows下使用Visual S ...
随机推荐
- CoreCRM 开发实录 —— Profile
再简单的功能,也需要一坨代码的支持.Profile 的编辑功能主要就是修改个人的信息.比如用户名.头像.性别.电话--虽然只是一个编辑界面,但添加下来,涉及了6个文件的修改和7个新创建的文件.各种生成 ...
- 使用Visual Studio 2015 开发ASP.NET MVC 5 项目部署到Mono/Jexus
最新的Mono 4.4已经支持运行asp.net mvc5项目,有的同学听了这句话就兴高采烈的拿起Visual Studio 2015创建了一个mvc 5的项目,然后部署到Mono上,浏览下发现一堆错 ...
- jQuery学习之路(1)-选择器
▓▓▓▓▓▓ 大致介绍 终于开始了我的jQuery学习之路!感觉不能再拖了,要边学习原生JavaScript边学习jQuery jQuery是什么? jQuery是一个快速.简洁的JavaScript ...
- 安卓易学,爬坑不易——腾讯老司机的RecyclerView局部刷新爬坑之路
针对手游的性能优化,腾讯WeTest平台的Cube工具提供了基本所有相关指标的检测,为手游进行最高效和准确的测试服务,不断改善玩家的体验.目前功能还在免费开放中. 点击地址:http://wetest ...
- ASP.NET Core: You must add a reference to assembly mscorlib, version=4.0.0.0
ASP.NET Core 引用外部程序包的时候,有时会出现下面的错误: The type 'Object' is defined in an assembly that is not referenc ...
- 最好的.NET开源免费ZIP库DotNetZip(.NET组件介绍之三)
在项目开发中,除了对数据的展示更多的就是对文件的相关操作,例如文件的创建和删除,以及文件的压缩和解压.文件压缩的好处有很多,主要就是在文件传输的方面,文件压缩的好处就不需要赘述,因为无论是开发者,还是 ...
- 不懂CSS的后端难道就不是好程序猿?
由于H5在移动端的发展如日中天,现在大部分公司对高级前端需求也是到处挖墙角,前端薪资也随之水涨船高,那公司没有配备专用的前端怎么办呢? 作为老板眼中的“程序猿” 前端都不会是非常无能的表现,那作为后端 ...
- ThinkPHP+Smarty模板中截取包含中英文混合的字符串乱码的解决方案
好几天没写博客了,其实有好多需要总结的,因为最近一直在忙着做项目,但是困惑了几天的Smarty模板中截取包含中英文混合的字符串乱码的问题,终于解决了,所以记录下来,需要的朋友看一下: 出现乱码的原因: ...
- 基于fis3的组件可视化道路
首先说明一下,即使不熟悉fis3,阅读文本应该也会有所收获. 本文以fis-parser-imweb-tplv2插件为模板插件,目的不在于使用哪个模板,而是组件可视化的实现思路,不必担心. 先说说模板 ...
- 登录(ajax提交数据和后台校验)
1.前台ajax数据提交 <form id="login_form" action="" method="POST"> < ...