【无标题】mysql 普通用户连接报错: MySql server has gone away

1、mysql 普通用户连接报错: MySql server has gone away

2、进入mysql错误日志位置查看输出日志显示错误为:

[Warning] [MY-013130] [Server] Aborted connection 47 to db: 'unconnected' user: 'tjcx' host: '10.195.11.4' (init_connect command failed; diagnostics area: MY-001273 - Unknown collation: 'server')

错误原因: cd /etc/my.cnf:

数据库配置文件中参数配置错误:

应该将配置改成 init_connect = "SET NAMES utf8mb4 COLLATE utf8mb4_general_ci"

关于MySQL的初始化连接设置。SET NAMES utf8mb4 COLLATE server=utf8mb4_general_ci这一句是用于设置MySQL连接的字符集和排序规则。

在正常情况下,这个语句应该在连接MySQL数据库后执行。它告诉MySQL你希望使用的字符集和排序规则。utf8mb4是字符集的名字,utf8mb4_general_ci是排序规则的名字。

但是,这个语句中有一个小错误。在指定排序规则时,server=utf8mb4_general_ci是不正确的。你可能想要使用COLLATE utf8mb4_general_ci来指定排序规则。因此,正确的语句应该是:

复制代码
复制代码
sql`SET NAMES 'utf8mb4' COLLATE 'utf8mb4_general_ci';`

你可以在连接到MySQL后,直接运行这条语句来设置字符集和排序规则。如果你是在一个脚本中设置这个,那么应该在你的脚本开始处运行这个语句。如果你是在命令行中设置这个,那么应该在连接MySQL后,立即运行这个语句。

相关推荐
卤炖阑尾炎6 分钟前
MySQL 主从复制与读写分离:从原理到实战全解析
mysql·adb
ego.iblacat7 分钟前
MySQL 高可用
数据库·mysql·adb
阿里小阿希12 分钟前
PostgreSQL 判断大导入是否正在执行 pg_stat_activity
数据库·postgresql
xrui5815 分钟前
PostgreSQL异常:An IO error occurred while sending to the backend
数据库·postgresql
卢傢蕊35 分钟前
PostgreSQL 初体验
数据库·postgresql
softshow102637 分钟前
PostgreSQL 12 完整部署+迁移+数据恢复
数据库·postgresql
bearpping39 分钟前
关于Mysql 中 Row size too large (> 8126) 错误的解决和理解
数据库·mysql
zhuiyisuifeng40 分钟前
PostgreSQL_安装部署
数据库·postgresql
watersink42 分钟前
第15章 数据库系统
数据库
一只专注api接口开发的技术猿1 小时前
商品详情API的SLA保障体系:监控告警、异常检测与自动化修复
运维·数据库·架构·自动化