mysql修改表、字段、库的字符集

本文详细介绍了如何在MySQL中修改数据库、表及字段的字符集,包括ALTER DATABASE、ALTER TABLE等命令的具体用法,并提供了查看数据库、表及字段编码的方法。

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

字符集

  • 修改数据库字符集:
 ALTER DATABASE db_name DEFAULT CHARACTER SET character_name [COLLATE ...];
 
  • 1
  • 1
  • 把表默认的字符集和所有字符列(CHAR,VARCHAR,TEXT)改为新的字符集:
ALTER TABLE tbl_name CONVERT TO CHARACTER SET character_name [COLLATE ...]
如:ALTER TABLE logtest CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci;
 
  • 1
  • 2
  • 1
  • 2
  • 只是修改表的默认字符集:
ALTER TABLE tbl_name DEFAULT CHARACTER SET character_name [COLLATE...];
如:ALTER TABLE logtest DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
 
  • 1
  • 2
  • 1
  • 2
  • 修改字段的字符集:
ALTER TABLE tbl_name CHANGE c_name c_name CHARACTER SET character_name [COLLATE ...];
如:ALTER TABLE logtest CHANGE title title VARCHAR(100) CHARACTER SET utf8 COLLATE utf8_general_ci;
 
  • 1
  • 2
  • 1
  • 2

批量修改表字符集

SELECT
CONCAT('alter table ',table_name,' CONVERT TO CHARACTER SET utf8 COLLATE utf8_unicode_ci;')
FROM
INFORMATION_SCHEMA.tables
WHERE
TABLE_SCHEMA='flowdb'  into outfile '/usr/local/temp/1.sql';
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 查看数据库编码: 
    SHOW CREATE DATABASE db_name;

  • 查看表编码: 
    SHOW CREATE TABLE tbl_name;

  • 查看字段编码: 
    SHOW FULL COLUMNS FROM tbl_name;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值