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

  之前介绍了My Blog如何使用ADO.NET来访问SQL Server获取数据。本章将介绍如何使用My SQL来完成数据管理。
  在使用My SQL之前需确保开发环境中安装了My SQL数据库和Connector/Net,后者是一个用C#编写的ADO.NET数据提供器,换句话说无论使用SQL Server还是My SQL,ASP.NET都是通过ADO.NET来访问、操作数据库的,它们唯一的区别是数据提供器,所以连接My SQL仍然需要使用System.Data.dll中的类型,以下是之前文章所介绍的:

 

  唯一不同的是My SQL的ADO.NET数据提供器是需要安装Connector/Net。

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

  ●安装My SQL和Connector/NET
  ●为My SQL创建一个新的仓储项目

安装My SQL和Connector/NET

  Connector/NET下载地址: https://dev.mysql.com/downloads/windows/installer/
  MySQL下载地址(安装时可以直接选择是否安装Connector/NET): https://dev.mysql.com/downloads/mysql/

  完成后添加数据表与数据:

  

为My SQL创建一个新的仓储项目

  为其创建一个新的项目原因是让SQL Server与My SQL共存,二者不会互相影响,到后期可以通过简单的修改来切换使用的数据库的目的。

  1. 创建一个新的类库项目BlogRepository.MySQL,并引用Mysql.Data(注:Mysql.Data需要安装Connector/NET):

  

  

  2. 使用执行SQL的方式实现一个BlogRepository:

  

  

  

  与SQL Server的代码对比,只有对象名称、SQL以及连接字符串存在差异。

  3. 变更逻辑层的引用,使用BlogRepository.MySQL,并修改错误的命名空间:

  

  

  4. 运行程序:

  

   

小结

  本章介绍了如何在ASP.NET中使用MySQL数据库,它的使用方式与SQL Server基本相同,只需要安装连接My SQL需要的组件即可。另外需要注意的一个问题是,现在在整个解决方案中分别有BlogRepository以及BlogRepository.MySQL两个仓储类库,分别对于SQL Server和My SQL但是逻辑层只有一个,这就意味着每次更换数据库业务逻辑库不仅要更换引用,还要修改代码。这就是典型的依赖实现而没有依赖抽象的问题。这个问题会在后续介绍解决方法。

参考:

  https://dev.mysql.com/doc/connector-net/en/connector-net-programming-connecting.html

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

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

原文地址:https://www.cnblogs.com/cool2feel/p/11544524.html

时间: 2024-10-03 22:38:26

ASP.NET开发实战——(八)ASP.NET MVC 与数据库之MySQL的相关文章

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

本文主要内容是通过分析<博客系统>需求,确定使用Web应用的形式来开发,然后介绍了HTML.HTTP的概念,并使用IIS搭建了一个静态的HTML“页面”,从而引出“动态”的ASP.NET. 本文从以下几个方面来介绍为什么使用ASP.NET: ●ASP.NET是什么? ●为什么使用ASP.NET? ●博客的需求及实现 ●什么是Web.HTML.Web服务器 ASP.NET是什么? ASP.NET是一个使用HTML.CSS.Javascript来构建动态网站或者网站应用程序的Web框架,并且也可以

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

上一篇文章对如何规范使用ASP.NET进行了介绍,本章内容将根据上一篇得出的结论来修改博客应用的代码. 代码分层 综合考虑将博客应用代码分为以下几个层次: ○ 模型:代表应用程序中的数据模型,与数据库表结构对应.同时也作为MVC与逻辑层之间的数据交换对象(后续会使用DTO代替). ○ 仓储:用于管理数据增.删.查.改. ○ 逻辑:用于处理业务逻辑,一般来说是根据应用层提供的数据来驱动业务执行,业务逻辑会使用仓储来对数据持久化. ○ 应用:也就是MVC应用,它为用户提供操作界面(UI),然后调用逻

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

前面的文章我们使用ASP.NET MVC创建了个博客应用,那么它是如何工作的呢?我们都知道ASP.NET的程序需要部署到IIS上才能够通过浏览器来访问,那么IIS与ASP.NET MVC程序之间又是如何工作的呢? 本章将从以下几个方面对ASP.NET的运行周期进行介绍: ●IIS及其管道配置 ●HttpApplication Events ●使用Global.asax注册事件 IIS及其管道配置 IIS(Internet Information Services)是微软在Windows操作系统上

ASP.NET开发实战——(七)ASP.NET与数据库

在之前的文章中介绍了使用ASP.NET MVC来开发一个博客系统,并且已将初具雏形,可以查看文章列表页面,也可以点击文章列表的其中一篇文章查看详情,这已经完成了最开始需求分析的读者的查看列表和查看文章两个需求,但是现在最大的问题是文章数据仍然是“静态”的. 所有数据被保存在内存中,系统在初始化时会自动添加被硬编码在代码文件中的数据,服务器每次重新启动都只会保留这些数据,并且没有提供“作者”的管理接口,“作者”没法来管理这些数据,哪怕是可以进行管理也没用,因为服务器重启后数据就不存在了,这才是最糟

Web Services 开发实战: 使用 ASP.NET Web API 2(繁体中文视频)

Web Services 開發實戰: 使用 ASP.NET Web API 2 (1) https://channel9.msdn.com/Blogs/Channel9Taiwan/Developing-Web-Services-Using-ASPNET-WebAPI2-Part1 https://channel9.msdn.com/Blogs/Channel9Taiwan/Developing-Web-Services-Using-ASPNET-WebAPI2-Part2 https://ch

Asp.Net 开发实战技术

1.什么是WMI技术 WMI是一项核心的Windows管理技术,WMI作为一种规范和基础结构,通过它可以访问.配置.管理和监视几乎所有的Windows资源,比如用户可以在远程计算机器上启动一个进程:设定一个在特定日期和时间运行的进程:远程启动计算机:获得本地或远程计算机的已安装程序列表:查询本地或远程计算机的Windows事件日志等等.WMI(Windows管理规范)作为一项Windows管理技术,方便用户对计算机进行远程管理.但是它的易用性也导致了系统的安全性大幅下降. ManagementP

2019java单体应用开发实战项目教程 bootstrap+mvc+spring+idea+maven技术整合

课程介绍:2019Java单体应用包含IDEA,Maven构建应用,三层架构 + MVC,Bootstrap,Spring等技术知识点├─软件├─第01天(14集)│ 005.第01章-使用 Intellij IDEA-第一个 IDEA 应用程序.mp4│ 006.小知识-使用 Markdown 记笔记.mp4│ 007.第02章-使用 Maven 构建应用-Maven 简介.mp4│ 008.第02章-使用 Maven 构建应用-Maven 安装配置.mp4│ 009.第02章-使用 Mave

ASP.NET开发学习视频教程大全(共800集)

ASP.NET是微软.NET平台的支柱之一,被广泛应用在WEB等互联网开发领域,因此它的强大性和适应性,可以使它运行在Web应用软件开发者的几乎全部的平台上.这里整理了最全的ASP.NET开发学习视频教程,总共八百集,一次看个够! 资料名称 下载地址 <ASP.NET4.0从入门到精通>随书教学视频  http://down.51cto.com/zt/2879 亮剑ASP.NET项目开发案例导航视频(含源码与PPT)  http://down.51cto.com/zt/2573 ASP.NET

《微软Azure云计算开发实战(2):Azure部署ASP.NET MVC 网站

今天我们继续学习Azure的实战开发,<微软Azure云计算开发实战(2):Azure部署ASP.NET MVC 网站. 在你注册完Azure的使用账户以后,下面就可以登陆Azure管理界面了.因为我们后续的开发工作都要用到Azure的资源. Azure作为公有云平台,提供了几乎所有的平台支持,操作系统包括Linux Mac OS Windows,数据库主流的都支持,网站空间,数据库,虚拟主机操作系统 几乎都有.还有流媒体服务,Hadoop集成,Bigtable等. 我们先来学习一下如何部署一个