`
fishermen
  • 浏览: 381030 次
社区版块
存档分类
最新评论

mysql 使用中的坑

 
阅读更多

        记录mysql使用中遇到的坑,备查。

 

1 字符集选择

        坑:一般人会直接选择utf8,但utf8字符集最多用3个bytes来描述一个字符,只包含BMP(Basic Multilingual Plane)字符,这样导致一些生僻字、无线互联网中的emoji表情符号等无法插入。

 

        方案:mysql升级到5.5.3以上,改用utf8mb4字符。utf8mb4最多采用4个bytes来描述一个字符,可以解决上述问题。而且对于BMP字符,utf8mb4和utf8占用的bytes数相同,这样不会消耗更多空间,而且从utf8到utf8mb4的升级也是兼容的。

 

        注意:javamysql驱动,需要5.1.13之后的版本才支持utf8mb4。

分享到:
评论

相关推荐

    linux mysql中的坑

    3. **使用引号包裹标识符**:在SQL语句中使用反引号(``)包裹表名和字段名也是一种解决方案。这样做可以让MySQL严格按照指定的大小写格式进行匹配,从而避免由于默认大小写敏感性带来的问题。 ```sql SELECT `...

    Linux中安装MySQL遇到的各种坑

    Linux中安装MySQL遇到的各种坑 在 Linux 系统上安装 MySQL 时可能会遇到各种问题,本文将记录这些问题并提供解决方法。 安装 NTP 在安装 MySQL 之前,需要安装 NTP(Network Time Protocol),以确保系统时间同步...

    从Oracle迁移到MySQL的那些坑.pdf

    例如,Oracle的序列(Sequence)在MySQL中没有直接对应,可能需要创建自增ID或使用UUID。Oracle的游标、%TYPE、PL/SQL包等特性在MySQL中也有不同的实现方式。 在进行迁移时,务必注意不要影响源数据库的正常运行,...

    MySQL踩得的坑

    在实际操作中,我们经常会遇到一些“坑”,这些坑可能源于对MySQL特性的不熟悉或者使用不当。这篇博客“MySQL踩得的坑”可能会帮助我们理解和避免这些问题。 首先,我们要理解MySQL中的NULL值。在SQL中,NULL表示...

    MySQL5.7中的sql_mode默认值带来的坑及解决方法

    在正常项目开发过程中,如果MySQL版本从5.6升级到5.7版本。作为DBA在考虑数据库版本升级带来的影响时,一般会有几个注意点: sql_mode optimizer_switch 本文主要内容是MySQL升级到5.7版本之后,由于默认的 sql_...

    centos7 安装mysql和mysqlclient遇到的坑总结

    安装完成后,启动MySQL服务,CentOS7中使用`systemctl start mysqld.service`。如果在较低版本的系统中,可以使用`service mysqld start`。检查MySQL服务状态则分别使用`systemctl status mysqld.service`或`service...

    EF连接MySql 5.7存在的坑

    使用Entity Framework 6.1.X连接MySQL5.7存在的几个问题的解决办法. 1.选择EF版本,弹出Your project references the latest version of EF;however,an EF database provider compatible with this version could ...

    VS2019+EF+Mysql生成实体数据模型(解决闪退的坑)VS2019+mysql+vs-mysql.rar

    最近使用VS2019连接数据库生成模型,生成实体,遇到的坑,找了好多资料在这里做个总结。 一、安装环境 mysql-installer-community-5.6.49.0.msi Visual Studio 2019专业版 mysql-for-visualstudio-1.2.9.msi

    Windows mysql8.0.36.0详细安装教程,附带MySQL安装包

    MySQL是一个广泛使用的开源关系型数据库管理系统(RDBMS),它在各种规模的企业和项目中扮演着核心角色。MySQL 8.0版本带来了许多性能提升、安全性改进以及新的功能,比如窗口函数和JSON字段的增强。 首先,我们...

    docker安装mysql踩过的坑.doc

    学习docker安装mysql我遇到很多坑,大约花了三天才解决掉这个问题,真的是太坎坷了,差点就放弃让我学习Java的心态了。首先往VM安装带有docker东西的虚拟机,查看ip地址是192.168.200.128.然后按照网上步骤docker ...

    java使用mysql的escape遇到的坑.pdf

    本文将深入探讨在Java中使用MySQL的`escape`功能时可能出现的陷阱。 首先,我们需要理解MySQL的`LIKE`语句中的转义规则。在`LIKE`语句中,`%`和`_`是特殊字符,它们分别代表任意数量的字符和单个字符。为了在字符串...

    mysql5.7 windows bat脚本一键安装.zip

    尽管这个脚本已经声明“无坑”且“亲测通过”,但在实际使用时,还是需要注意一些事项: - 确保系统满足MySQL 5.7的最低硬件和软件需求。 - 脚本可能需要管理员权限才能执行。 - 遵循脚本的使用说明,理解其运行...

    mysql order by limit 的一个坑.docx

    使用 ORDER BY 和 LIMIT 两个关键字需要注意可能出现的坑,我们需要确保 ORDER BY 列中包含一个索引列,以避免出现不确定的查询结果。同时,我们也可以使用 MySQL 的 LIMIT 优化方法来提高查询效率。

    浅谈mysql8.0新特性的坑和解决办法(小结)

    MySQL 8.0引入了许多新特性,但同时也带来了一些与旧版本不兼容的问题,这使得在升级或初次使用时可能会遇到一些“坑”。本文将详细探讨这些新特性及其潜在问题,以及如何解决这些问题。 首先,关于创建用户和授权...

    MysqlOperation.zip

    相对之下,Mysql官方的C接口还算比较友好的了,但是使用起来仍然略显繁琐. 为此,自己封装了一些C操作Mysql官方提供的操作API,用它操作Mysql可谓so easy 测试程序代码在test.c中,为一个查询一张表所有数据,一共就...

    mysql转oracle要注意的几项

    例如,给定文件中的第一段代码展示了如何在Oracle中使用`CASE WHEN`来替代MySQL中的`IF`函数。具体而言: ```sql -- Oracle SELECT (CASE WHEN NVL(列1, 0) > 0 AND NVL(列2, 0) > 10 THEN 1 ELSE 0 END) AS num ...

    mysql主从复制搭建(避免采坑)

    mysql主从复制 踩完坑给大家 3分 完整,让大家少踩坑.

    springboot2.1.3 + mysql(mybatis) + mongodb maven项目

    MySQL是一种广泛使用的开源关系型数据库管理系统,以其高性能、稳定性及易于管理而受到青睐。在本项目中,MySQL用于存储结构化数据,如用户信息、订单详情等。MyBatis是一个优秀的持久层框架,它支持定制化SQL、存储...

    emoji入库mysql注意事项除了更改utf8mb4最大的坑在这里

    - **PDO连接字符串中指定字符集**:在使用PDO连接MySQL时,务必在连接字符串中指定`charset=utf8mb4`,以确保MySQL使用`utf8mb4`字符集接收数据。示例代码如下: ```php $pdo = new PDO("mysql:host=localhost;...

Global site tag (gtag.js) - Google Analytics