第一步:找到下图两个组件,卸载。

第二步: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的更多相关文章

  1. sqlserver数据库导入Mysql数据库问题

    近来遇到一个问题,之前的项目用的是SQLServer数据库,但是现在要换成MySQL数据库,所有整理了一些数据导入的步骤,供需要的人参考! 第一步: 第二步: 第三步: 第四步: 第五步: 第六步: ...

  2. Navicat Premium 将sqlserver 数据库 导入mysql 中

    1.新建 MySQL 数据库  2.  3 4 5 6 7 8 9一直点击下一步 10 成功

  3. 【项目经验】navicat工具 SQLServer数据库迁移MySQL

    新近领了一个任务,就是把SQL Server的数据库迁移到My Sql上,经过查资料,圆满完成任务.分享一下流程. 1.首先,在自己的My Sql数据库上新建一个数据库. 2.打开新建的My Sql数 ...

  4. SQLServer数据库转换成MySQL数据库

    由于工作需要,系统原先的SQLServer数据库要转换成MYSQL数据库,所以这两天就一直在查阅这方面的资料.最开始,我尝试从SQLServer中导出SQL文件,然后导入到MYSQL数据库中,发现报错 ...

  5. 怎样将Sqlserver数据库转成mysql数据库

    手上有一个网站之前是用asp.net做的,所使用的数据库是sqlserver,现在打算用PHP+MYSQL架构.因原来的站点有一定排名,直接改版的话,会导致产生很多错误页,网站排名和收录结果要恢复过来 ...

  6. SQL多表连接查询以及mysql数据库、sqlserver数据库常见不同点

    mysql数据库表及数据准备语句: USE test; DROP TABLE IF EXISTS `teacher_table`; DROP TABLE IF EXISTS `student_tabl ...

  7. EntityFramework 多数据库链接,MySql,SqlServer,Oracel等

    环境:EntityFramework5.0,MySql5.6,MSSQL2012 EF是强大的ORM工具,真正意义上的多数据库链接指的是不同类型的数据库,以及同种类型的数据库多个库,EF很好的支持这一 ...

  8. SQLServer 远程链接MySql数据库详解

    SQLServer 远程链接MySql数据库详解 by:授客 QQ:1033553122 测试环境: Microsoft Windows XP Professional 版本2000 Service ...

  9. spring BasicDataSource 数据源配置 sqlserver数据库 oracle数据库 mysql数据jdbc配置

    spring BasicDataSource 数据源配置 sqlserver数据库 oracle数据库 mysql数据jdbc配置 jdbc.properties 文件信息如下: ---------- ...

随机推荐

  1. FineReport中日期时间函数使用总结

    说明:凡函数中以日期作为参数因子的,其中日期的形式都必须是yy/mm/dd.而且必须用英文环境下双引号(" ")引用. DATE DATE(year,month,day):返回一个 ...

  2. springboot+web文件上传和下载

    一.首先安装mysql数据库,开启web服务器. 二.pom.xml文件依赖包配置如下: <?xml version="1.0" encoding="UTF-8&q ...

  3. java线程学习之wait方法

    wait 等待方法是让线程进入等待队列,使用方法是 obj.wait(); 这样当前线程就会暂停运行,并且进入obj的等待队列中,称作“线程正在obj上等待”. 如果线程想执行 wait 方法,线程必 ...

  4. JS 页面表格的操作

    var showObj = null;var arr = [ ['编号','姓名','性别','年龄','备注','操作'], ['1','lisi','nan','12','66666'], ['2 ...

  5. js中创建对象的4种方法

    1.直接创建,不可复用式创建var obj = new Object(); obj.name = ""; obj.id = ""; 2.使用工厂方法来创建对象, ...

  6. MySQL高性能优化规范建议,速度收藏

    数据库命令规范 •所有数据库对象名称必须使用小写字母并用下划线分割•所有数据库对象名称禁止使用 MySQL 保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来)•数据库对象的命名要能做到见 ...

  7. 依据word模板批量生成试卷

    java-word-MassProduction 目录 使用方法 开发流程 一.使用方法 1.制造题库所需Word模板 需要填充数据的地方使用 ${pid} 代替. 将这个word选择另存为,保存格式 ...

  8. [c/c++] programming之路(27)、union共用体

    共用体时刻只有一个变量,结构体变量同时并存 一.创建共用体的三种形式 #include<stdio.h> #include<stdlib.h> #include<stri ...

  9. CEF 自定义用户协议(scheme)实现以二进制流的方式显示图片、视频、音频

    转载:https://www.cnblogs.com/sinceret/p/10417941.html 转载:https://stackoverflow.com/questions/48811756/ ...

  10. Java 诊断工具 Arthas 教程学习笔记

    Java 诊断利器 Arthas,是阿里的一款开源工具.Github-alibaba/arthas 上可以看到它的介绍.了解它,主要是最近对分析 Java 错误堆栈比较感兴趣,机缘巧合看到了它. 本文 ...