使用VS2013操作MYSQL8 (ADO.NET方式 & EF6)
今天有时间测试了一下通过.net环境操作MYSQL数据库,测试过程及结果记录如下:
1、MYSQL安装
(1)我是从MYSQL官网下载的最新版,即MYSQL8.0,在MySql官网的下载页面,找到“MySQL Installer for Windows”。
MySql下载页面地址:https://dev.mysql.com/downloads/
上图中,MySql for Visual Studio和Connector/NET用于后边的EF操作,MySQL Installer for Windows为Windows上的安装文件下载。
(2)MySql一共提供两种安装方式,一种本地安装,一个是在线安装,我是下载的本地安装文件。如图:
下载之后一路“Next”,具体安装方式不详述,可以参考相关文章。
安装完成后,顺便装了一个MySql可视化工具:Navicat for mysql。关于Navicat for mysql的破解安装,可以参考:https://blog.csdn.net/mqingo/article/details/84314685。
然后在MySql建了一个测试库Test,同时建了一张测试表:Student,为便于测试,只设置了两个字段:Id和Name。
2、ADO.NET方式操作MySql
.(1)NET操作MySql,需要先引用MySQL.Data.dll,这个文件的默认位置在:C:\Program Files (x86)\MySQL\Connector NET 8.0\Assemblies\v4.5.2。打开这个文件夹,可以看到除了这个MySQL.Data.dll,MySql官方还提供了其他一些如:MySql.Data.EntityFramework.dll的文件,后面会用到,其他像MySQL.Data.EntityFrameworkCore.dll应该是针对.net Core的相应提供程序。
(2)新建一个.net控制台应用程序,引用上面提到的MySQL.Data.dll。通过对象浏览器查看,可以看到MySQL.Data.dll提供了诸如ADO访问SqlServer的相关功能。如:MySqlConnection 、MySqlCommand、MySqlDataAdapter、MySqlDataReader等,所不同的只是由Sql换成了Mysql。
(3)设置数据库连接字符串,编写相关代码进行测试,几个内置对象的用法与SqlServer完全相同,不同的只是MySql本身的SQL语法个别与SqlServer不同,因此在执行SQL时应该注意。
class Program
{
static void Main(string[] args)
{
string connstr = "Server=localhost;User Id=root;Password=******;PersistSecurityInfo=True;Port=3306;DataBase=test;Charset=utf8mb4;SslMode=none"; //插入数据
using (MySqlConnection conn = new MySqlConnection(connstr))
{
MySqlCommand cmd = new MySqlCommand("INSERT INTO Student (name) VALUES('test12')", conn);
conn.Open();
cmd.ExecuteNonQuery();
} //数据读取器测试
using (MySqlConnection conn = new MySqlConnection(connstr))
{
MySqlCommand cmd = new MySqlCommand("SELECT * FROM Student", conn);
conn.Open();
MySqlDataReader sdr = cmd.ExecuteReader(CommandBehavior.CloseConnection);
while(sdr.Read())
{
Console.WriteLine(string.Format("Id:{0} Name:{1}", sdr["Id"], sdr["Name"]));
}
} //DataSet测试
using (MySqlConnection conn = new MySqlConnection(connstr))
{
MySqlDataAdapter sda = new MySqlDataAdapter("SELECT * FROM Student", conn);
DataTable dt = new DataTable();
sda.Fill(dt);
foreach(DataRow dr in dt.Rows)
{
Console.WriteLine(string.Format("Id:{0} Name:{1}", dr["Id"], dr["Name"]));
}
} using (MySqlConnection conn = new MySqlConnection(connstr))
{ }
}
}
(4)测试结果
注意事项:
MySql 8的MySql.Data.dll要求.net Framework版本最低为v4.5.2,通过MySql.Data.dll所在路径也能看出来
如果低于此版本,在代码编译期会无法通过,提示:未能找到类型或命名空间名称“MySql”(是否缺少 using 指令或程序集引用?)
3、EF方式操作MySql
采用EF方式操作MySql,需要先安装两个插件,然后还需要通过NuGet安装EF,中间可能会踩坑。具体步骤如下:
(1)安装Visual Studio 2013所需插件
在使用Visual Studio 2013添加ADO.NET实体数据模型新建连接时,默认是没有Mysql选项的。此时我们需要安装两个东西:
1、mysql-for-visualstudio:Mysql的Visual Studio插件。
mysql-for-visualstudio的官网下载地址:https://dev.mysql.com/downloads/windows/visualstudio/,MySql官网默认提供的版本是1.2.9的安装包,但1.2.9是不支持VS2013的,如果安装1.2.9版本的话,会提示最低要求你的VS版本是2015。
此时我们可以下载低版本的安装包,在刚才的下载页面上,点击“Looking for previous GA versions?”,如图:
点击后,在页面上下载1.1.4版本的安装包。
2、mysql-connector-net:.net连接Mysql的程序。
网上有资料说,这个.net连接程序并非越高越好,但我既然安装了MySql 8,自然这个mysql-connector-net也要安装对应的版本。
mysql-connector-net安装包下载地址:https://dev.mysql.com/downloads/connector/net/
(2)通过NuGet安装EF
完成上面的两个插件安装后,在添加ADO.NET数据库时的数据源选择就会出现MySql选择项,如图:
在选择EF版本的时候,会报错,提示找不到兼容的实体框架提供程序。如图所示:
解决办法如下:
1、先通过NuGet安装EntityFramework 6.0
Install-Package EntityFramework -Version 6.0.0
Install-Package EntityFramework.zh-Hans -Version 6.0.0
2、在你的项目中引入C:\Program Files (x86)\MySQL\Connector NET 8.0\Assemblies\v4.5.2下MySql.Data.dll和MySql.Data.EntityFramework.dll两个文件。
3、在项目配置文件的entityFramework节点下的providers节点增加一个提供程序:
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<configSections>
<!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
<section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
</configSections>
<startup>
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5.2" />
</startup>
<entityFramework>
<defaultConnectionFactory type="System.Data.Entity.Infrastructure.LocalDbConnectionFactory, EntityFramework">
<parameters>
<parameter value="v11.0" />
</parameters>
</defaultConnectionFactory>
<providers>
<provider invariantName="MySql.Data.MySqlClient" type="MySql.Data.MySqlClient.MySqlProviderServices, MySql.Data.EntityFramework"></provider>
<provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
</providers>
</entityFramework>
<connectionStrings>
<add name="testEntities" connectionString="***" providerName="System.Data.EntityClient" />
</connectionStrings>
</configuration>
注意红色标识部分,即:MySql.Data.EntityFramework,要与你的MySql.Data.EntityFramework.dll中的命名空间保持一致,此处版本不同要引用的程序集名称也不相同。
4、重新生成项目,一定要重新生成项目!
5、重新添加ADO.NET实体数据模型,已经可以添加成功,如图:
6、可以进行一个简单测试,测试代码如下:
class Program
{
static void Main(string[] args)
{
testEntities db = new testEntities(); //添加数据
db.student.Add(new student { Name = "这是一个测试" });
db.SaveChanges(); //读取数据
foreach(var p in db.student)
{
Console.WriteLine(p.Name);
}
}
}
以上是VS2013连接MySql的一些记录,其中.net版本,以及相关安装包的版本选择要注意,本文没有进行更多的测试,还有其他的很多坑没有踩,踩到再说吧。
使用VS2013操作MYSQL8 (ADO.NET方式 & EF6)的更多相关文章
- IOS文件操作的两种方式:NSFileManager操作和流操作
1.常见的NSFileManager文件方法 -(NSData *)contentsAtPath:path //从一个文件读取数据 -(BOOL)createFileAtPath: path cont ...
- 计算属性 vs 侦听属性 当需要在数据变化时执行异步或开销较大的操作时,这个方式是最有用的
https://cn.vuejs.org/v2/guide/computed.html#基础例子 计算属性 vs 侦听属性 Vue 提供了一种更通用的方式来观察和响应 Vue 实例上的数据变动:侦听属 ...
- c++ 操作Mysql ado
#pragma once #ifndef DB_MYSQL_H #define DB_MYSQL_H #include "stdafx.h" #include <wins ...
- Attribute操作的性能优化方式
Attribute是.NET平台上提供的一种元编程能力,可以通过标记的方式来修饰各种成员.无论是组件设计,语言之间互通,还是最普通的框架使 用,现在已经都离不开Attribute了.迫于Attribu ...
- VS2012 Unit Test —— 我对IdleTest库动的大手术以及对Xml相关操作进行测试的方式
[1]我的IdleTest源码地址:http://idletest.codeplex.com/ [2]IdleTest改动说明:2013年10月份在保持原有功能的情况下对其动了较大的手术,首先将基本的 ...
- Spring实现初始化和销毁bean之前进行的操作,三种方式
关于在spring 容器初始化 bean 和销毁前所做的操作定义方式有三种: 第一种:通过@PostConstruct 和 @PreDestroy 方法 实现初始化和销毁bean之前进行的操作 第二 ...
- [转]Windows系统中监控文件复制操作的几种方式
1. ICopyHook 作用: 监视文件夹和打印机移动,删除, 重命名, 复制操作. 可以得到源和目标文件名. 可以控制拒绝操作. 缺点: 不能对文件进行控制. 只对Shell文件操作有效, 对原生 ...
- 数据库操作(ADO)
QTP工具本身自带有数据查询和验证功能,但是使用的人会感觉这个功能使用起来比较麻烦,灵活性和复用性较低,于是我们选择了用脚本调用ADO组件实现数据库的操作,现总结下工作中用到的数据库操作,代码如下: ...
- C#操作Excel的OLEDB方式与COM方式比较
2013-03-15 13:42:54 作者:有理想的码农 在对Excel进行读写操作时,使用微软自身提供的解决方案,有两种(第三方方式除外),分别是OLEDB方式和调用COM组件的方式 ...
随机推荐
- WCF尝试创建与发布IIS(含问题描述)
技术贴技术贴就直接讲技术来,客套的话我也不多说了,各位看官包涵包涵. 跟着园内高手一步一步发布成功,欣喜若狂之际,发个贴纪念纪念一下. 废话不多说,不正确之处,还望大家积极指出,共同进步.哈哈~~~ ...
- 【HIVE】各种时间格式处理
yyyy-MM-dd与yyyyMMdd000000转换的三种方法 方法一:date_format(只支持yyyy-MM-dd -> yyyyMMdd000000) select date_for ...
- Map(映射)
散列表介绍: 数组和链表都可以是有序的(即存储顺序与取出顺序一致),但这样是有代价的,需要遍历才可以寻找某一特定元素: 而还有另外的一些存储结构:不在意元素的顺序,能够快速的查找元素的数据 其中就有一 ...
- ActiveMQ学习总结------入门篇01
注:*这篇博文文章主要介绍ActiveMQ是什么原理性的内容和如何安装和简易操作 一. ActiveMQ 简介 1 ActiveMQ是什么呢?看起来好碉堡的东西哇! ActiveMQ 是 Apach ...
- Java 学习笔记之 线程sleep方法
线程sleep方法: 单主线程使用sleep: Main线程差了2000毫秒. public class MainSleepThread extends Thread{ @Override publi ...
- 整理一些大厂的开源平台及github,向他们看齐...
有人苦恼,该如何突破技术的局限性... 有人羡慕,技术上你怎么懂得这么多... 有人哀叹,唉,我已经学不动了... 我的总结(纯属个人想法):身处IT,就得不断学习和积累,才不会被狠狠地甩在身后.什么 ...
- AlexNet模型的解析及tensorflow实现
AlexNet是ImageNet LSVRC 2012比赛中分类效果第一的深度神经网络模型,点击链接下载论文http://papers.nips.cc/paper/4824-imagenet-clas ...
- .NET进阶篇-语言章-2-Delegate委托、Event事件
知识只有经过整理才能形成技能 整个章节分布简介请查看第一篇 内容目录 一.概述 二.解析委托知识点 1.委托本质 2.委托的使用 3.委托意义 逻辑解耦,减少重复代码 代码封装支持扩展 匿名方法和La ...
- 洛谷 P2145 [JSOI2007]祖码
题目描述 这是一个流行在Jsoi的游戏,名称为祖玛. 精致细腻的背景,外加神秘的印加音乐衬托,彷佛置身在古老的国度里面,进行一个神秘的游戏——这就是著名的祖玛游戏.祖玛游戏的主角是一只石青蛙,石青蛙会 ...
- HTML5远程工具
因为有从网页直接远程其他windows电脑的需求,于是通过网上搜索找到下面几个解决方案,分享一下: 1.windows的远程桌面web连接tsweb 下载地址https://www.microsoft ...