.NET SQLServer数据库转MySql
第一步:找到下图两个组件,卸载。


第二步:NuGet下载下图组件。

第三步:在连接数据库OnConfiguring方法处,做如下修改:
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
var config = new ConfigurationBuilder()
.SetBasePath(Directory.GetCurrentDirectory())
.AddJsonFile("appsettings.json")
.Build();
optionsBuilder.UseMySQL(config.GetConnectionString("DefaultConnection"));
}
第四步:映射的字段属性。
有三个字段类性需要重点说一下 GUID、DateTimeOffset、bool
1. GUID类型在SQLServer能用,却不能被MySql使用,所以所有的GUID类型的字段属性在换数据库的时候,MySql表的此字段都要指定变更为varchar类型。在代码中 .NET的string对应MySql数据库的varchar,所以在代码中映射时如下:
public class TestMap : EntityMappingConfiguration<TestEntity>
{
public override void Map(EntityTypeBuilder<TestEntity> builder)
{
builder.ToTable("Base_Test").HasKey(c => c.TestId);
builder.Property(c => c.TestId).HasColumnName("TestId").HasColumnType("string");
builder.Property(c => c.IsDeleted).HasColumnName("IsDeleted").HasColumnType("bit");
builder.Property(c => c.CreateDateTime).HasColumnName("CreateDateTime");
}
}
若不加.HasColumnType("bit")则会报如下图的错误。
(Unable to cast object of type 'System.String' to type 'System.Byte[]'.)

2. DateTimeOffset类型在SQLServer能用,却不能被MySql使用,所以所有的DateTimeOffset类型的字段属性在换数据库的时候,MySql表的此字段都要指定变更为DateTime类型。
public class TestMap : EntityMappingConfiguration<TestEntity>
{
public override void Map(EntityTypeBuilder<TestEntity> builder)
{
builder.ToTable("Base_Test").HasKey(c => c.TestId);
builder.Property(c => c.TestId).HasColumnName("TestId").HasColumnType("string");
builder.Property(c => c.CreateDateTime).HasColumnName("CreateDateTime");
}
}
3. 所有的bool类型的字段属性在换数据库的时候,可指定变更为bit类型。在代码中 .NET的 bool对应MySql数据库的bit,所以在代码中映射时如下:
public class TestMap : EntityMappingConfiguration<TestEntity>
{
public override void Map(EntityTypeBuilder<TestEntity> builder)
{
builder.ToTable("Base_Test").HasKey(c => c.TestId);
builder.Property(c => c.TestId).HasColumnName("TestId").HasColumnType("string");
builder.Property(c => c.IsDeleted).HasColumnName("IsDeleted").HasColumnType("bit");
builder.Property(c => c.CreateDateTime).HasColumnName("CreateDateTime");
}
}
若不加.HasColumnType("bit")则可能会报如下图的错误。
(System.InvalidOperationException:“No coercion operator is defined between types 'System.Int16' and 'System.Boolean'.”)

若程序中定义的字段属性与数据库表中的字段属性对应不上,则可能会报如下图的错误。
(Unable to cast object of type 'System.String' to type 'System.Byte[]'.)
至此,换库完成。
已解决,但不理解的问题:var test = db.Test.Any(i => i.IsDelected==true) 会报如下错误:
(System.InvalidOperationException:“No coercion operator is defined between types 'System.Int16' and 'System.Boolean'.”)

解决方法:先ToList()即可,
var test = db.Test.ToList().Any(i => i.IsDelected==true)
.NET SQLServer数据库转MySql的更多相关文章
- sqlserver数据库导入Mysql数据库问题
近来遇到一个问题,之前的项目用的是SQLServer数据库,但是现在要换成MySQL数据库,所有整理了一些数据导入的步骤,供需要的人参考! 第一步: 第二步: 第三步: 第四步: 第五步: 第六步: ...
- Navicat Premium 将sqlserver 数据库 导入mysql 中
1.新建 MySQL 数据库 2. 3 4 5 6 7 8 9一直点击下一步 10 成功
- 【项目经验】navicat工具 SQLServer数据库迁移MySQL
新近领了一个任务,就是把SQL Server的数据库迁移到My Sql上,经过查资料,圆满完成任务.分享一下流程. 1.首先,在自己的My Sql数据库上新建一个数据库. 2.打开新建的My Sql数 ...
- SQLServer数据库转换成MySQL数据库
由于工作需要,系统原先的SQLServer数据库要转换成MYSQL数据库,所以这两天就一直在查阅这方面的资料.最开始,我尝试从SQLServer中导出SQL文件,然后导入到MYSQL数据库中,发现报错 ...
- 怎样将Sqlserver数据库转成mysql数据库
手上有一个网站之前是用asp.net做的,所使用的数据库是sqlserver,现在打算用PHP+MYSQL架构.因原来的站点有一定排名,直接改版的话,会导致产生很多错误页,网站排名和收录结果要恢复过来 ...
- SQL多表连接查询以及mysql数据库、sqlserver数据库常见不同点
mysql数据库表及数据准备语句: USE test; DROP TABLE IF EXISTS `teacher_table`; DROP TABLE IF EXISTS `student_tabl ...
- EntityFramework 多数据库链接,MySql,SqlServer,Oracel等
环境:EntityFramework5.0,MySql5.6,MSSQL2012 EF是强大的ORM工具,真正意义上的多数据库链接指的是不同类型的数据库,以及同种类型的数据库多个库,EF很好的支持这一 ...
- SQLServer 远程链接MySql数据库详解
SQLServer 远程链接MySql数据库详解 by:授客 QQ:1033553122 测试环境: Microsoft Windows XP Professional 版本2000 Service ...
- spring BasicDataSource 数据源配置 sqlserver数据库 oracle数据库 mysql数据jdbc配置
spring BasicDataSource 数据源配置 sqlserver数据库 oracle数据库 mysql数据jdbc配置 jdbc.properties 文件信息如下: ---------- ...
随机推荐
- delphi 判断端口(Port)是否被占用(转载)
function IsPortUsed(aPort: Integer): Boolean; var _vSock: TSocket; _vWSAData: TWSAData; _vAddrIn: TS ...
- Elasticsearch从入门到精通之Elasticsearch集群内的原理
上一章节我介绍了Elasticsearch安装与运行,本章节及后续章节将全方位介绍 Elasticsearch 的工作原理 在这个章节中,我将会再进一步介绍 cluster . node . shar ...
- 读取FTP 图片文件,并显示,非下载
关于FTP,先从怎么创建开始说起,很简单,步骤就两个 ① 电脑-右键管理--本地用户组--添加用户名,密码(用于FTP的用户名.密码) ② IIS 新建FTP站点,命名,指定端口号.FTP文件路径 接 ...
- 【kafka学习之六】kakfa消息生产、消费示例
环境 虚拟机:VMware 10 Linux版本:CentOS-6.5-x86_64 客户端:Xshell4 FTP:Xftp4 jdk1.8 kafka_2.11-0.11.0.0 zookeepe ...
- shell脚本的一些常用操作
字符串长度: ${#string}可获取string字符串的长度,如下: jenkins@soft1pc:~$ str="who are you"jenkins@soft1pc:~ ...
- 如何在linux上查看tomcat的端口号
1.先到tomcat配置文件查看tomcat的端口是什么,配置文件一般是:$CATALINA_HOME/conf/server这个文件,查找<Connector port="8080& ...
- 在java中使用ssm框架的定时的实现
1.首先需要在application.xml里面配置如下的代码: xmlns:task="http://www.springframework.org/schema/task http:// ...
- LeetCode 整数反转
给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转. 示例 1: 输入: 123 输出: 321 示例 2: 输入: -123 输出: -321 示例 3: 输入: 120 输出: ...
- ltp-ddt git
ltp-ddt目录下有一个文件夹 confrVOaeL confvp5WrA 这个文件夹是由./configure --host=arm-linux-gnueabihf命令生成的. 每次configu ...
- 多态 鸭子类型 反射 内置方法(__str__,__del__) 异常处理
''' 1什么是多态 多态指的是同一种/类事物的不同形态 2 为何要有多态 多态性:在多态的背景下,可以在不用考虑对象具体类型的前提下而直接使用对象 多态性的精髓:统一 多态性的好处: 1增加了程序的 ...