MySQL批量修改数据表和数据表中所有字段的字符集

由于Mysql的utf8是有缺陷的,不是真正的UTF-8,utf8mb4才是真正的UTF-8。

对于一些老的项目要修改字符集,可以参照我的另外一篇文章:

MySQL数据库字符集utf8如何转utf8mb4   https://blog.csdn.net/vfsdfdsf/article/details/89672717

本文使用的数据库版本是:5.7.17

 

更改表编码(字符集)和表中所有字段的编码(字符集):

ALTER TABLE TABLE_NAME CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;

如果一个数据库有很多表要修改,可以使用如下办法:

查询某个数据库所有表名的语句:

SELECT TABLE_NAME from information_schema.`TABLES` WHERE TABLE_SCHEMA = 'DATABASE_NAME';

 

得到所有的表名,我们可以把表名拼接到上面更改表编码(字符集)和表中所有字段的编码(字符集)的语句中去,得到如下语句:

 
  1. SELECT

  2. CONCAT(

  3. 'ALTER TABLE ',

  4. TABLE_NAME,

  5. ' CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;'

  6. )

  7. FROM

  8. information_schema.`TABLES`

  9. WHERE

  10. TABLE_SCHEMA = 'DATABASE_NAME';

执行后得到的就是修改数据库中所有表字符集的语句,然后复制这些语句执行就可以了。

下面我以mysql数据库为例进行操作:

把语句执行得到的结果集复制出来就是批量更新的语句,在数据库中执行即可

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
根据引用\[1\]和\[2\]的信息,可以使用导出和导入数据的方法来批量修改MySQL表的数据。通过使用OUTFILE命令将数据导出到一个文件,然后对文件进行修改,最后使用LOAD DATA INFILE命令将修改后的数据导入到表。这种方法可以大大减少数据库的查询操作次数,节约系统资源。同时,根据引用\[2\]的说明,这种方法的性能比一次性插入一条数据快20倍。 另外,根据引用\[3\]的信息,需要注意SQL语句的长度限制。如果SQL语句超过了程序运行环境所支持的字符串长度,可以通过更新MySQL的设置来扩展。可以通过执行"show variables like 'max_allowed_packet'"命令来查看当前的max_allowed_packet设置,然后根据需要修改my.cnf文件的max_allowed_packet参数,或者使用"set global max_allowed_packet=10000000"命令来修改全局级的设置,或者使用"set session max_allowed_packet=10000000"命令来修改会话级的设置。 综上所述,可以使用导出和导入数据的方法来批量修改MySQL表的数据,并根据需要修改max_allowed_packet参数来避免SQL语句长度限制的问题。 #### 引用[.reference_title] - *1* *2* *3* [MySql几种批量更新/新增/删除的方法](https://blog.csdn.net/hudeyong926/article/details/104831441)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

人间四月天美丽春色

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值