Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 1052|回复: 0

关于使用SqlSugar插入数据异常解决方案

[复制链接]
  • TA的每日心情
    奋斗
    前天 12:49
  • 签到天数: 789 天

    [LV.10]以坛为家III

    2049

    主题

    2107

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    722638
    发表于 2021-5-2 10:23:24 | 显示全部楼层 |阅读模式

     项目的解决方案中引用的有mysqlsugar的数据库操作库,在使用插入数据过程中一些特殊的生僻字或表情符号总会提示:

    Incorrect string value: '\xF0\x9F...' for column 'name' at row 1

    这是由于UTF-8编码有可能是两个、三个、四个字节。Emoji表情或者某些特殊字符是4个字节,而MySQL的utf8编码最多3个字节,所以数据插不进去。

    进而提示\x十六进制的字符串信息。

    因为myselsugar ,也是对sqlsugar的进一步封装。所以将目光聚焦在sqlsugar上就可以了。

    sqlsugar给的解决方案是:

    在定义实体时将临时保存特殊字符的变量mapping(映射)sqlsugar中的[SqlSugar.SugarColumn(IsTranscoding =true)] //设置该自段转码 属性

    例:

     1 using System;
     2 using System.Linq;
     3 using SqlSugar;
     4 
     5 namespace ClearMonitor.Model.Entities
     6 {
     7     [SqlSugar.SugarTable("departmentintro")]
     8     public  class DepartmentintroData
     9     {
    10         public int DepartmentId { get; set; }
    11         public string DepartmentNo { get; set; }
    12         public string DepartmentName { get; set; }
    13         /// <summary>
    14         /// 部门简介
    15         /// </summary>
    16         [SqlSugar.SugarColumn(IsTranscoding =true)]
    17         public string DepartmentBlurb { get; set; }
    18 
    19     }
    20 }
    View Code
    最后是官方论坛的解决方案,也贴在下面了。MySql插入表情方案,感谢支持。如有问题请及时沟通联系。

     补充说明:实体特性API

    ColumnName  定义数据库表字段的真实名称,当一样的时候可以不定义该特性
    IsIgnore   不作数据库操作,true将不会进行查询、添加等操作
    IsPrimaryKey  标识是否为主键,更新的时候会根据主键值判段更新哪条,当InitKey为Attribute时一定要加该特性不然找不到主键
    IsIdentity  是否为自增长
    ColumnDescription  列描述
    Length  长度,生成表会用到
    IsNullable 是否可空,生成表会用到
    OldColumnName  修改列名,生成表会用到
    ColumnDataType  自定义生成的数据类型,生成表会用到
    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-9-8 12:03 , Processed in 1.079235 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表