thinkphp mysql 如何对指定表使用指定字符编码进行查询和操作?

发布于 2022-09-03 11:35:25 字数 855 浏览 20 评论 0

问题是这样的:
有一数据库,里面有很多表,也有很多已存在的数据,这些数据多数都是用utf8存储的(不全是,还有latin1的)。
遇到了用户存emoji导致存储失败的问题,已知是需要utf8mb4才能正确存储。

已经把mysql从5.1升级到5.6.26了。接下来的想法和已有的尝试:
1、如果把整个数据库都更新成uft8mb4的话,风险太大,因为各种调用的地方乱七八糟,维护不良,直接变成utf8mb4的话可能整个系统都不正常。

2、考虑只把用户会存储emoji的表(以下简称表E)更新成uft8mb4,然而这里系统用的是thinkphp写的,编码设置是放在config.php中的,修改这里的话,thinkphp就全灭了。

3、接着2考虑的话,thinkphp主体仍然用uft8不变,仅在查询这个表E的时候临时使用uft8mb4进行查询。尝试M()->query('SET NAMES \'utf8mb4\'');结果报错:SQLSTATE[HY000]: General error

4、仍然考虑2的方法发现也不行。因为即使查询了这个表E成功之后,又会进行其他表的操作,uft8mb4又可能会导致接下来的查询出错。

求助有没有好的办法能只针对这一个表进行以utf8mb4为编码的操作,并且还不影响其他表的操作。

PS:因为生产环境已经上线一年了已有很多数据和在线用户,而现在测试才报出来有这个问题。数据库整体更新编码实在风险太大,领导的意思是哪有坑先填哪,没发现的坑就假装没看见。
幸运的是生产环境当时搭建系统时是我安装的,mysql一开始就是当时的最新版5.6.26。emoji再转码的方法希望只作为最后的解决办法。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

寄意 2022-09-10 11:35:25

请问这个问题最后是怎么解决的呢?我也遇到同样的场景,想在写入时单独设置utf8mb4,据说utf8mb4是utf8的超集,但有点不放心

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文