ASP.NET MVC使用ADO.NET连接数据库
深入理解ADO.NET友情链接:http://www.cnblogs.com/liuhaorain/category/352388.html
小白手把手:VS2017 SQL Server 2014
第一步:新建项目,选择Visual C#--ASP.NET Web Application(.NET Framework),键入工程名。确认后选择MVC模式,确认。

此时可看到工程目录包含Controllers,Modles,Views三层。运行程序即可看到VS自带的MVC模板。

第二步,新建工程完成后,进行数据库的连接,若还没有在数据库建好表,则先行建表,建好后进行以下操作。
点击工具栏的Tools--Connect to Database,填写你所连接的数据库的Server name,选择身份验证,输入用户名和密码,然后选择所要连接的数据库名称。

1.右键Models选择新建项目,选择Data--ADO.NET Entity Data Model,然后确认;

2.选择Code First from database,点击Next

3.在连接处选择起初我们建立好的连接,或者略过起初建立连接,在此处选择新建连接。

或
选择Yes,include the sensitive data in the connection string.点击Next,选择将要使用的数据库对象,包括“表”、“视图”、“存储过程和函数”。点击Finish.
完成后会看到Models文件夹添加了实体数据模型,Web.config文件添加了连接数据库配置。

<connectionStrings><add name="Joke" connectionString="data source=PA181;user id=sa;password=**;MultipleActiveResultSets=True;App=EntityFramework" providerName="System.Data.SqlClient" /></connectionStrings>
第三步,新建Controller,右键Controllers文件add--Controller,选择MVC5 Controller with read/write actions点击add,命名是后面Controller不要改动。
生成的controller中包含action:

第四步,在controllers文件中新建DBConnect类,用来进行数据库的连接读写操作。
using ADO.NET.test.Models;
using System;
using System.Collections.Generic;
using System.Configuration;
using System.Data.SqlClient;
using System.Linq;
using System.Web; namespace ADO.NET.test.Controllers
{
public class DB
{
protected SqlConnection conn;
//打开连接
public bool OpenConnection()
{
conn = new SqlConnection(ConfigurationManager.ConnectionStrings["Joke"].ConnectionString);
try
{
bool result = true;
if (conn.State.ToString() != "Open")
{
conn.Open();
}
return result;
}
catch (SqlException ex)
{
return false;
}
}
//关闭连接
public bool CloseConnection()
{
try
{
conn.Close();
return true;
}
catch (SqlException ex)
{
return false;
}
}
//显示
public List<Joke> Select()
{
SqlDataReader sdr;
List<Joke> list = new List<Joke>();
try
{
if (conn.State.ToString() == "Open")
{
SqlCommand cmd = new SqlCommand("Select * from Jokes", conn);
sdr = cmd.ExecuteReader();
while (sdr.Read())
{
Joke j = new Joke();
System.Diagnostics.Debug.WriteLine("ID:{0}\tcontent:{1}\tbelong:{2}\tstate:{3}\ttime:{4}", sdr["ID"], sdr["Content"], sdr["Belong"], sdr["State"], sdr["AddDate"]);
j.ID = Convert.ToInt32(sdr["ID"]);
j.Content = sdr["Content"].ToString();
j.Belong = sdr["Belong"].ToString();
j.State = Convert.ToInt32(sdr["State"]);
j.AddDate = Convert.ToDateTime(sdr["AddDate"]); list.Add(j);
}
}
}
catch (Exception e)
{
Console.WriteLine("Joke details wrong:{0}", e);
}
finally
{
conn.Close();
}
return list;
}
//Detail
public Joke Detail(int? id)
{
SqlDataReader sdr;
Joke j = new Joke();
System.Diagnostics.Debug.WriteLine("编号:{0}", id);
string sql = "Select * from Jokes where ID = @ID";
SqlParameter[] paras = new SqlParameter[]{//参数数组
new SqlParameter("@ID",System.Data.SqlDbType.Int)};
paras[].Value = id;//绑定ID
try
{
if (conn.State.ToString() == "Open")
{
SqlCommand cmd = new SqlCommand(sql, conn);
cmd.Parameters.AddRange(paras);
sdr = cmd.ExecuteReader();
while (sdr.Read())
{ System.Diagnostics.Debug.WriteLine("ID:{0}\tcontent:{1}\tbelong:{2}\tstate:{3}\ttime:{4}", sdr["ID"], sdr["Content"], sdr["Belong"], sdr["State"], sdr["AddDate"]);
j.ID = Convert.ToInt32(sdr["ID"]);
j.Content = sdr["Content"].ToString();
j.Belong = sdr["Belong"].ToString();
j.State = Convert.ToInt32(sdr["State"]);
j.AddDate = Convert.ToDateTime(sdr["AddDate"]);
}
}
}
catch (Exception e)
{
System.Diagnostics.Debug.WriteLine("Joke select wrong:{0}", e);
}
finally
{
conn.Close();
}
return j; }
//Create
public void Create(Joke joke)
{
//SqlDataReader sdr;
//string sql = "insert into Jokes(Content,Belong,State,AddDate)values('" + joke.Content + "','" + joke.Belong + "','" + joke.State + "','" + joke.AddDate + "')";
string sql = "insert into Jokes(Content,Belong,State,AddDate)values(@content,@belong,@state,@time)";
SqlParameter[] paras = new SqlParameter[]{//参数数组
new SqlParameter("@content",System.Data.SqlDbType.VarChar),
new SqlParameter("@belong",System.Data.SqlDbType.VarChar),
new SqlParameter("@state",System.Data.SqlDbType.Int),
new SqlParameter("@time",System.Data.SqlDbType.DateTime)};
paras[].Value = joke.Content;//绑定内容
paras[].Value = joke.Belong;//绑定署名
paras[].Value = joke.State;//绑定状态
paras[].Value = joke.AddDate;//绑定时间
try
{
if (conn.State.ToString() == "Open")
{
SqlCommand cmd = new SqlCommand(sql, conn);
cmd.Parameters.AddRange(paras);
cmd.ExecuteNonQuery();
System.Diagnostics.Debug.WriteLine("插入成功!");
}
}
catch (Exception e)
{
Console.WriteLine("Joke create wrong:{0}", e);
}
finally
{
conn.Close();
}
}
//Delete
public int Delete(int? id)
{
string sql = "delete from Jokes where ID= @ID";
SqlParameter[] paras = new SqlParameter[]{//参数数组
new SqlParameter("@ID",System.Data.SqlDbType.Int)};
paras[].Value = id;//绑定ID
int i = ;
try
{
if (conn.State.ToString() == "Open")
{
SqlCommand cmd = new SqlCommand(sql, conn);
cmd.Parameters.AddRange(paras);
i = cmd.ExecuteNonQuery();
System.Diagnostics.Debug.WriteLine("插入成功!");
}
}
catch (Exception e)
{
Console.WriteLine("Joke create wrong:{0}", e);
}
finally
{
conn.Close();
}
return i;
}
//update
public int Update(Joke joke)
{
string sql = "update Jokes set Content = @content,Belong = @belong where ID= @ID";
SqlParameter[] paras = new SqlParameter[]{//参数数组
new SqlParameter("@content",System.Data.SqlDbType.VarChar),
new SqlParameter("@belong",System.Data.SqlDbType.VarChar),
new SqlParameter("@ID",System.Data.SqlDbType.Int)};
paras[].Value = joke.Content;//绑定内容
paras[].Value = joke.Belong;//绑定署名
paras[].Value = joke.ID;//绑定ID
System.Diagnostics.Debug.WriteLine("SQL语句:{0}", sql);
int i = ;
try
{
if (conn.State.ToString() == "Open")
{
SqlCommand cmd = new SqlCommand(sql, conn);
cmd.Parameters.AddRange(paras);
i = cmd.ExecuteNonQuery();
System.Diagnostics.Debug.WriteLine("更新成功!");
}
}
catch (Exception e)
{
Console.WriteLine("Joke update wrong:{0}", e);
}
finally
{
conn.Close();
}
return i;
}
}
}
第五步:在Views--Joke文件夹下建立对应的Controller返回显示页面。

第六步,App_Start--RouteConfig.cs修改路由,使初始页面指向Joke--Index.cshtml.

最后运行结果:

ASP.NET MVC使用ADO.NET连接数据库的更多相关文章
- CRUD Operations In ASP.NET MVC 5 Using ADO.NET
Background After awesome response of an published by me in the year 2013: Insert, Update, Delete In ...
- ASP.NET MVC + ADO.NET EF 项目实战(一):应用程序布局设计
什么叫上下文? 在你设计一个方法的时候,无法直接从方法参数或实例成员(字段或属性)获得的所有信息都是上下文.例如: 当前用户是谁? 刚才提供操作的数据库连接实例从哪里拿到? 这个方法从哪个 View ...
- ADO.NET .net core2.0添加json文件并转化成类注入控制器使用 简单了解 iTextSharp实现HTML to PDF ASP.NET MVC 中 Autofac依赖注入DI 控制反转IOC 了解一下 C# AutoMapper 了解一下
ADO.NET 一.ADO.NET概要 ADO.NET是.NET框架中的重要组件,主要用于完成C#应用程序访问数据库 二.ADO.NET的组成 ①System.Data → DataTable, ...
- ASP.NET MVC+JQueryEasyUI1.4+ADO.NET Demo
1.JQueryEasyUI使用 JQuery EasyUI中文官网:http://www.jeasyui.net/ JQuery EasyUI中文官网下载地址:http://www.jeasyui. ...
- 第1章 (ASP.NET MVC简介)
一.MVC概念 MVC由三部分组成:视图(View).模型(Model).控制器(Controller)组成 二.运用VS创建MVC 1.新建一个"解决方案" 2.在"解 ...
- [ASP.NET MVC 小牛之路]06 - 使用 Entity Framework
在家闲着也是闲着,继续写我的[ASP.NET MVC 小牛之路]系列吧.在该系列的上一篇博文中,在显示书本信息列表的时候,我们是在程序代码中手工造的数据.本文将演示如何在ASP.NET MVC中使用E ...
- 如鹏网学习笔记(十五)ASP.NET MVC核心基础笔记
一.ASP.Net MVC简介 1,什么是ASP.NET MVC? HttpHandler是ASP.net的底层机制,如果直接使用HttpHandler进行开发难度比较大.工作量大.因此提供了ASP. ...
- ASP.NET MVC深入浅出系列(持续更新) ORM系列之Entity FrameWork详解(持续更新) 第十六节:语法总结(3)(C#6.0和C#7.0新语法) 第三节:深度剖析各类数据结构(Array、List、Queue、Stack)及线程安全问题和yeild关键字 各种通讯连接方式 设计模式篇 第十二节: 总结Quartz.Net几种部署模式(IIS、Exe、服务部署【借
ASP.NET MVC深入浅出系列(持续更新) 一. ASP.NET体系 从事.Net开发以来,最先接触的Web开发框架是Asp.Net WebForm,该框架高度封装,为了隐藏Http的无状态模 ...
- ASP.net MVC 构建layui管理后台(构造基础仓储)<1>
本文章为ASP.net MVC 构建layui管理后台,第一篇. 使用EF+ado.net 实体数据模型模式进行底层的数据库连接. 在项目添加一个类库Model 在类库Model上添加一个ado.ne ...
随机推荐
- February 9th, 2018 Week 6th Friday
Every one of us want to ameliorate our own condition. You can only cure retail but you can prevent w ...
- MATLAB插 值 法
MATLAB插 值 法 作者:凯鲁嘎吉 - 博客园http://www.cnblogs.com/kailugaji/ 一.实验目的 二.实验原理 三.实验程序 四.实验内容 五.解答 1. 程序 ...
- File类_删除一个带内容的目录_练习
需求:删除一个带内容的目录 原理:必须从最里面往外删除需要深度遍历 import java.io.File; public class RemoveDirTest { public static vo ...
- nginx与location语法详解
Location语法优先级排列 匹配符 匹配规则 优先级 = 精确匹配 ^~ 以某个字符串开头 ~ 区分大小写的正则匹配 ~* 不区分大小写的正则匹配 !~ 区分大小写不匹配的正则 !~* 不区分大小 ...
- 从源码的角度分析List与Set的区别
很多时候我们在讨论List与Set的异同点时都在说: 1.List.Set都实现了Collection接口 2.List是有序的,可以存储重复的元素,允许存入null 3.Set是无序的,不允许存储重 ...
- 牛客小白D题(STL的迭代器)
「只要我拉动绳线,你就得随之起舞.」 ——泰兹瑞 泰兹瑞来到卡拉德许之后,由于他精湛的神器制造技术,可谓是过的如鱼得水.这次,他为自己打造了一个编辑器,称为威穆(Vei ...
- WINS服务器与DNS服务器有什么区别?
1.WINS实现的是IP地址和计算机名称的映射,DNS实现的是IP地址和域名的映射.2.WINS作用的范围是某个内部网络,DNS的范围是整个互联网.简单说明一下:WINS实现的是IP地址和计算机名称的 ...
- 搭建OpenResty(Nginx+Lua)
这篇文章是一个多月前写的,当时之所以搭建这个是为了最大程度上发挥Nginx的高并发效率(主要是结合lua脚本),参考的话,主要参考张开涛先生写的跟开涛学Nginx+lua系列文章,地址为:https: ...
- Python脱产8期 Day03 2019/4/15
一 变量的命名规范 1.只能由 字母, 数字, _, 组成. 2. 不能以数字开头 3.避免与系统关键字重名:重名不会报错,但系统的功能就被自定义的功能屏蔽掉了(严重不建议这样来做) 4.以_开头的 ...
- Objective-C 实现读写锁
读写锁 @interface RWLock : NSObject - (void)readLock; - (void)readUnlock; - (void)writeLock; - (void)wr ...