深入理解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连接数据库的更多相关文章

  1. 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 ...

  2. ASP.NET MVC + ADO.NET EF 项目实战(一):应用程序布局设计

    什么叫上下文? 在你设计一个方法的时候,无法直接从方法参数或实例成员(字段或属性)获得的所有信息都是上下文.例如: 当前用户是谁? 刚才提供操作的数据库连接实例从哪里拿到? 这个方法从哪个 View ...

  3. 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, ...

  4. ASP.NET MVC+JQueryEasyUI1.4+ADO.NET Demo

    1.JQueryEasyUI使用 JQuery EasyUI中文官网:http://www.jeasyui.net/ JQuery EasyUI中文官网下载地址:http://www.jeasyui. ...

  5. 第1章 (ASP.NET MVC简介)

    一.MVC概念 MVC由三部分组成:视图(View).模型(Model).控制器(Controller)组成 二.运用VS创建MVC 1.新建一个"解决方案" 2.在"解 ...

  6. [ASP.NET MVC 小牛之路]06 - 使用 Entity Framework

    在家闲着也是闲着,继续写我的[ASP.NET MVC 小牛之路]系列吧.在该系列的上一篇博文中,在显示书本信息列表的时候,我们是在程序代码中手工造的数据.本文将演示如何在ASP.NET MVC中使用E ...

  7. 如鹏网学习笔记(十五)ASP.NET MVC核心基础笔记

    一.ASP.Net MVC简介 1,什么是ASP.NET MVC? HttpHandler是ASP.net的底层机制,如果直接使用HttpHandler进行开发难度比较大.工作量大.因此提供了ASP. ...

  8. 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的无状态模 ...

  9. ASP.net MVC 构建layui管理后台(构造基础仓储)<1>

    本文章为ASP.net MVC 构建layui管理后台,第一篇. 使用EF+ado.net 实体数据模型模式进行底层的数据库连接. 在项目添加一个类库Model 在类库Model上添加一个ado.ne ...

随机推荐

  1. 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 ...

  2. MATLAB插 值 法

    MATLAB插  值  法 作者:凯鲁嘎吉 - 博客园http://www.cnblogs.com/kailugaji/ 一.实验目的 二.实验原理 三.实验程序 四.实验内容 五.解答 1. 程序 ...

  3. File类_删除一个带内容的目录_练习

    需求:删除一个带内容的目录 原理:必须从最里面往外删除需要深度遍历 import java.io.File; public class RemoveDirTest { public static vo ...

  4. nginx与location语法详解

    Location语法优先级排列 匹配符 匹配规则 优先级 = 精确匹配 ^~ 以某个字符串开头 ~ 区分大小写的正则匹配 ~* 不区分大小写的正则匹配 !~ 区分大小写不匹配的正则 !~* 不区分大小 ...

  5. 从源码的角度分析List与Set的区别

    很多时候我们在讨论List与Set的异同点时都在说: 1.List.Set都实现了Collection接口 2.List是有序的,可以存储重复的元素,允许存入null 3.Set是无序的,不允许存储重 ...

  6. 牛客小白D题(STL的迭代器)

    「只要我拉动绳线,你就得随之起舞.」          ——泰兹瑞        泰兹瑞来到卡拉德许之后,由于他精湛的神器制造技术,可谓是过的如鱼得水.这次,他为自己打造了一个编辑器,称为威穆(Vei ...

  7. WINS服务器与DNS服务器有什么区别?

    1.WINS实现的是IP地址和计算机名称的映射,DNS实现的是IP地址和域名的映射.2.WINS作用的范围是某个内部网络,DNS的范围是整个互联网.简单说明一下:WINS实现的是IP地址和计算机名称的 ...

  8. 搭建OpenResty(Nginx+Lua)

    这篇文章是一个多月前写的,当时之所以搭建这个是为了最大程度上发挥Nginx的高并发效率(主要是结合lua脚本),参考的话,主要参考张开涛先生写的跟开涛学Nginx+lua系列文章,地址为:https: ...

  9. Python脱产8期 Day03 2019/4/15

    一 变量的命名规范 1.只能由 字母, 数字,  _, 组成. 2. 不能以数字开头 3.避免与系统关键字重名:重名不会报错,但系统的功能就被自定义的功能屏蔽掉了(严重不建议这样来做) 4.以_开头的 ...

  10. Objective-C 实现读写锁

    读写锁 @interface RWLock : NSObject - (void)readLock; - (void)readUnlock; - (void)writeLock; - (void)wr ...