首页 技术 正文
技术 2022年11月23日
0 收藏 444 点赞 5,172 浏览 941 个字

使用 Pomelo.EntityFrameworkCore.MySql 生成 MySQL 数据库

关于如何使用请查看项目文档即可

组件地址:https://github.com/PomeloFoundation/Pomelo.EntityFrameworkCore.MySql

问题描述

遇到的是在使用 CodeFirst 生成数据库的字符集编码问题

执行迁移命令:Add-Migration 版本 , Update-Database 生成数据库(若无自动创建)的字符集为 latin1 -- cp1252 West European

此字符集将会在生成查询语句包含中文的时候报如下错误

异常信息

Illegal mix of collations (latin1_swedish_ci,IMPLICIT) and (utf8mb4_bin,COERCIBLE) for operation '='MySql.Data.MySqlClient.MySqlException (0x80004005): Illegal mix of collations (latin1_swedish_ci,IMPLICIT) and (utf8mb4_bin,COERCIBLE) for operation '=' ---> MySql.Data.MySqlClient.MySqlException (0x80004005): Illegal mix of collations (latin1_swedish_ci,IMPLICIT) and (utf8mb4_bin,COERCIBLE) for operation '='

解决方案

其实组件最开始就建议了设置字符集为:utf8mb4(MySQL5.5.3及以上),所以遇到上诉错误只需要执行修改数据库字符集命令即可

  • 手动创建字符集为utf8mb4的数据库再执行迁移
  • 命令修改字符集:alter database 数据库名称 character set utf8mb4;,但是注意这并不能修改已创建的表的字符集编码;故还是建议手动创建数据库。

相关命令

  • 查看MySQL数据库字符集:show variables like 'character_set_database';
  • 修改MySQL数据库字符集:alter database 数据库名称 character set utf8mb4;
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,955
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,479
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,291
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,108
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,740
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,774