mysql 表情字符插入异常解决方案

本文介绍了一种在MySQL中插入表情字符导致的问题及其解决方案。通过使用正则表达式过滤并替换表情字符为指定符号,可以有效避免因表情字符引发的数据插入错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

mysql 表情字符插入异常:Incorrect string value: '\xF0\x9F\x90\xB7",...' for column 解决方案对表情字符进行过滤替换,如下

 /**
         * 将emoji表情替换成*
         *
         * @param source
         * @return 过滤后的字符串
         */
        public static String filterEmoji(String source) {
            if(StringUtils.isNotBlank(source)){
                return source.replaceAll("[\\ud800\\udc00-\\udbff\\udfff\\ud800-\\udfff]", "*");
            }else{
                return source;
            }
        }
        public static void main(String[] args){
            try{
                String text = "This is a smiley \uD83C\uDFA6 face\uD860\uDD5D \uD860\uDE07 \uD860\uDEE2 \uD863\uDCCA \uD863\uDCCD \uD863\uDCD2 \uD867\uDD98 ";
                System.out.println(text);
                System.out.println(text.length());
                System.out.println(text.replaceAll("[\\ud83c\\udc00-\\ud83c\\udfff]|[\\ud83d\\udc00-\\ud83d\\udfff]|[\\u2600-\\u27ff]", "*"));
                System.out.println(filterEmoji(text));
            }catch (Exception ex){
                ex.printStackTrace();
            }
        }
复制代码

##输出结果

This is a smiley ? face? ? ? ? ? ? ?

45

This is a smiley * face? ? ? ? ? ? ?

This is a smiley * face* * * * * * *

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值