在之前的文章中介绍了使用ASP.NET MVC来开发一个博客系统,并且已将初具雏形,可以查看文章列表页面,也可以点击文章列表的其中一篇文章查看详情,这已经完成了最开始需求分析的读者的查看列表和查看文章两个需求,但是现在最大的问题是文章数据仍然是“静态”的。
  所有数据被保存在内存中,系统在初始化时会自动添加被硬编码在代码文件中的数据,服务器每次重新启动都只会保留这些数据,并且没有提供“作者”的管理接口,“作者”没法来管理这些数据,哪怕是可以进行管理也没用,因为服务器重启后数据就不存在了,这才是最糟糕的。最初使用HTML文件保存的文章虽然不易修改,但至少数据以文件的形式被保存在硬盘上,只要硬盘不坏,那么数据永远不会丢失,但是现在不一样了,要如何对数据进行持久化呢?
  数据库是最好的选择(有的时候也会需要使用文件来管理数据,需要根据实际的应用场景来选择,如配置文件),当然也可以使用文件的方式来管理数据,其实数据库也是一种特殊的文件,只不过数据库文件可以特有的访问方式来对数据进行管理,如插入、删除、更新和快速查找等等,这些功能都不需要自己编写,它们是数据库管理系统提供的(DBMS,Database Management System),数据库又存在很多种类型,在一般企业级应用中常用的是关系型数据库,主要有SQL Server、MySQL、Oracle、PostgreSQL等,它们都能够为应用程序的数据存储提供可靠保证。
  对于ASP.NET来说最常用且提供支持最多的当然是SQL Server,但是由于MySQL和PostgreSQL都是开源的,一定程度上可以对其免费使用,所以也经常被.NET开发人员使用,本系列文章将使用SQL Server和MySQL两种数据库来实现数据存储功能,同时也可以看出不同数据库对一个应用程序会有哪些影响。

  本文通过以下两点来介绍如何在ASP.NET中使用SQL Server数据库:

  ●使用SQL Server存储数据
  ●在ASP.NET中访问SQL Server

使用SQL Server存储数据

  1. 使用SQL Server创建Blog数据库,以及Posts表,表字段对应Post类(如何使用SQL Server不在本系列文章范围内,所以会忽略很多细节):

  

  2. 在表中添加数据:

  

在ASP.NET中访问SQL Server

  文章前面说过数据库其实也是一种特殊的文件,然后通过特有的访问方式来使用它,那么ASP.NET 要如何连接并使用SQL Server呢?ADO.NET。(ADO.NET更多信息参考:http://blog.csdn.net/dreamcatchergo/article/details/9729525
  现在修改原有通过静态数组获取数据的BlogRepository,使用ADO.NET来获取数据库中的数据,ADO.NET相关的类在System.Data.dll程序集中,而ADO.NET对于不同的数据源提供了不同的数据提供器,它们用于连接不同的数据源:
  SQL Server:System.Data.SqlClient
  OleDb: System.Data.OleDb
  Odbc: System.Data.Odbc
  Oracle: System.Data.OracleClient

  在本例中使用的是SQL Server,所以需要System.Data以及System.Data.SqlClient的支持,System.Data在创建项目时以及默认存在。

  1. 通过Nuget包管理器安装System.Data.Sqlclient库:

  

  2. 修改BlogRepository,让其从数据库中获取数据:

  

  

  上面代码中有三个重要的对象分别是SqlConnection、SqlCommand、SqlDataReader,它们的作用分别是通过连接字符串连接数据库、通过SQL语句及参数执行SQL(也可以执行存储过程)、读取执行SQL返回的结果。

  3. 程序执行结果:

  

  

小结

  本章介绍了如何使用数据库来管理数据,然后通过ADO.NET来连接数据库,从数据库中获取文章数据,然后显示到页面上,现在这个应用程序已经“动”起来了,仅需要更新数据库的内容,页面内容也将随之而变。但存在一个问题就是每一次从数据库获取数据都要写SQL语句然后从返回的数据集中获取相应字段的数据用来创建实体对象。有没有更好的方法来解决?

  

参考:

  https://docs.microsoft.com/en-us/dotnet/framework/data/adonet/

  http://blog.csdn.net/dreamcatchergo/article/details/9729525

欢迎添加个人微信号:Like若所思。

欢迎关注我的公众号,不仅为你推荐最新的博文,还有更多惊喜和资源在等着你!一起学习共同进步!

ASP.NET开发实战——(七)ASP.NET与数据库的更多相关文章

  1. ASP.NET开发实战——(二)为什么使用ASP.NET

    本文主要内容是通过分析<博客系统>需求,确定使用Web应用的形式来开发,然后介绍了HTML.HTTP的概念,并使用IIS搭建了一个静态的HTML“页面”,从而引出“动态”的ASP.NET. ...

  2. ASP.NET开发实战——(一)开篇-用VS创建一个ASP.NET Web程序

        本文是本系列文章第一篇,主要通过建立一个默认ASP.NET MVC项目来引出与ASP.NET MVC相关的功能,由于ASP.NET MVC一个简单的模板就具备了数据库操作.身份验证.输入数据校 ...

  3. ASP.NET开发实战——(九)ASP.NET MVC 与数据库之ORM

    之前的文章中介绍了如何在ASP.NET中通过ADO.NET操作SQL Server和My SQL数据库,数据库的操作是通过SQL语句的执行来完成的,在ASP.NET中还有一个简便的方式来使用数据库,那 ...

  4. ASP.NET开发实战——(八)ASP.NET MVC 与数据库之MySQL

    之前介绍了My Blog如何使用ADO.NET来访问SQL Server获取数据.本章将介绍如何使用My SQL来完成数据管理. 在使用My SQL之前需确保开发环境中安装了My SQL数据库和Con ...

  5. ASP.NET开发实战——(五)ASP.NET MVC & 分层

    上一篇文章简要说明了MVC所代表的含义并提供了详细的项目及其控制器.视图等内容的创建步骤,最终完成了一个简单ASP.NET MVC程序. 注:MVC与ASP.NET MVC不相等,MVC是一种开发模式 ...

  6. ASP.NET开发实战——(三)第一个ASP.NET应用《MyBlog》

    本文开始通过ASP.NET MVC创建一个博客应用,该应用是通过默认的MVC模板修改而来,所以创建的过程和代码都与默认模板一致,然后通过修改的方式将默认模板改为博客的主页,并添加博客列表.内容等页面. ...

  7. ASP.NET开发实战——(十)ASP.NET MVC 与数据库之MySQL&EF

    之前介绍EF时介绍了provider这个配置项,而且也介绍了在ASP.NET访问MySQL数据仍然是通过ADO.NET,不同的地方仅仅是更换了MySQL的数据提供器,那么在EF中是否也只需更换“提供器 ...

  8. ASP.NET开发实战——(六)ASP.NET MVC & 分层 代码篇

    上一篇文章对如何规范使用ASP.NET进行了介绍,本章内容将根据上一篇得出的结论来修改博客应用的代码. 代码分层 综合考虑将博客应用代码分为以下几个层次: ○ 模型:代表应用程序中的数据模型,与数据库 ...

  9. ASP.NET开发实战——(四)ASP.NET MVC是如何运行的?它的生命周期是什么?

    前面的文章我们使用ASP.NET MVC创建了个博客应用,那么它是如何工作的呢?我们都知道ASP.NET的程序需要部署到IIS上才能够通过浏览器来访问,那么IIS与ASP.NET MVC程序之间又是如 ...

随机推荐

  1. C#开发BIMFACE系列23 服务端API之获取模型数据8:获取模型链接信息

    系列目录     [已更新最新开发文章,点击查看详细] 在Revit等BIM设计工具中可以给模型的某个部位添加链接信息.即类似于在Office Word.Excel 中给一段文字添加本地文件链接或者网 ...

  2. JS做的类似腾讯专题图片播放器,大家可以一起来改进!

    我是一个应届生,来公司不久,根据需求,网站需要一个专题图片轮播的页面.网上确实有很多现成的插件,但是,作为一个JS还不是很牛的应届生,我决定自己写一个! 话说忽然想到做个这个还真不容易,一时思绪理不清 ...

  3. java(一)基础知识

    常见DOS命令: dir:列出当前目录下的文件以及文件夹 md:创建目录 rd: 删除目录 cd:进入指定目录 cd .. :返回上一级目录 cd \:返回根目录 del:删除文件 exit:退出do ...

  4. jieba 分词使用入门

    1. 介绍 JIEBA 是目前最好的 Python 中文分词组件,它主要有以下 3 种特性: 支持 3 种分词模式:精确模式.全模式.搜索引擎模式 支持繁体分词 支持自定义词典 import jieb ...

  5. 框架基础:深入理解Java注解类型(@Annotation)

    注解的概念 注解的官方定义 首先看看官方对注解的描述: An annotation is a form of metadata, that can be added to Java source co ...

  6. 练手WPF(一)——模拟时钟与数字时钟的制作(中)

    今天接着制作数字时钟 数字时钟主要用到Path控件,主要用于定义数字笔划的形状. (1)添加一个DigitLine类 数字时钟的数字8由7笔组成,看如下定义的字段字符串数组PathDatas,每个st ...

  7. Hive_hdfs导入csv文件

    转自:Hive_hdfs csv导入hive demo   1 create csv file.student.csv 4,Rose,M,78,77,76 5,Mike,F,99,98,98 2 pu ...

  8. Java生鲜电商平台-商品基础业务架构设计-商品设计

    Java生鲜电商平台-商品基础业务架构设计-商品设计 在生鲜电商的商品中心,在电子商务公司一般是后台管理商品的地方.在前端而言,是商家为了展示商品信息给用户的地方,它是承担了商品的数据,订单,营销活动 ...

  9. Node.js提供了哪些内容(API)

    Nodejs运行时,JavaScript代码运行时的环境. 提供了一些核心模块,应用程序编程接口(Application Program Interface,API)  API 的意思就是.一个已经解 ...

  10. python 计算 对象 占用大小

    # 这里主要是计算文件内容(str)的大小即: 统计空间占用情况, 并转换宜读单位 K,M def gen_atta_size(con): # 参数可以是任意数据类型 if con: size_b = ...