MySQL错误信息1356
错误:1000 SQLSTATE: HY000 (ER_HASHCHK) 消息:hashchk错误:1001 SQLSTATE: HY000 (ER_NISAMCHK) 消息:isamchk错误:10...
2024.11.15前言:
有时候我们会遇到重命名表的需求,比如说因业务变化,需要将表 a 重命名为表 b 。这个时候可以执行 rename TABLE 语句或 ALTER TABLE 语句来重命名表。本篇文章我们一起来学习下重命名表相关知识。
1.重命名表方法使用 rename TABLE 语句或 ALTER TABLE 语句都可以对表进行重命名,基本语法如下:
# rename TABLE 语法:rename TABLEtbl_name TO new_tbl_name[, tbl_name2 TO new_tbl_name2] ...# ALTER TABLE 语法:ALTER TABLE old_table rename new_table;# 具体示例:mysql> show tables;+------------------+| Tables_in_testdb |+------------------+| tb1|| tb2|+------------------+2 rows in set (0.00 sec)mysql> rename table tb1 to new_tb1;Query OK, 0 rows affected (0.03 sec)mysql> alter table tb2 rename new_tb2;Query OK, 0 rows affected (0.04 sec)mysql> show tables;+------------------+| Tables_in_testdb |+------------------+| new_tb1|| new_tb2|+------------------+2 rows in set (0.00 sec)显然易见,在执行重命名表时,旧表(old_table_name)必须存在,而新表(new_table_name)一定不存在。如果新表 new_table_name 确实存在,该语句将失败。
执行重命名表的用户必须具有原始 table 的 ALTER 和 drop 权限,以及新 table 的 CREATE 和 insert 权限。与 ALTER TABLE 不同,rename TABLE 可以在单个语句中重命名多个表:
rename TABLE old_table1 TO new_table1, old_table2 TO new_table2, old_table3 TO new_table3;若一次性重命名多个表,则重命名操作从左到右执行。因此,要交换两个表名,可以执行此操作(假设中间表名称为tmp_table且不存在):
rename TABLE old_table TO tmp_table, new_table TO old_table, tmp_table TO new_table;通过重命名表,我们还可以将一个表从一个数据库移动到另一个数据库中,语法如下:
rename TABLE current_db.tbl_name TO other_db.tbl_name;ALTER TABLE current_db.tbl_name rename other_db.tbl_name;# 拼接SQL 实现将某个数据库中的表全部转移至另一个数据库中SELECTCONCAT( ‘rename table old_db.‘, TABLE_NAME, ‘ to new_db.‘, TABLE_NAME, ‘;‘ ) FROMinformation_schema.TABLES WHERETABLE_SCHEMA = ‘old_db‘;事实上,MySQL 并没有提供重命名数据库的操作,我们可以通过将某个库的所有表都通过重命名转移到另一个库中,来间接实现重命名库,只是原库仍然存在。
2.注意事项值得注意的是,重命名操作是原子完成的,需要获取该表的元数据锁,因此我们在执行 rename TABLE 前,要确保该表没有活跃的事务且没有被锁定。因为只需更改元数据,所以对于大表重命名也是很迅速的。此外,如果该表具有触发器,则无法将该表通过重命名方式转移到另外一个库中。
其实,rename TABLE 语句和 ALTER TABLE 语句还是有部分区别的,查询官方文档,主要有几点如下:
rename TABLE 适用于视图,但不能将视图重命名转移到其他数据库中,ALTER TABLE 不能重命名视图。ALTER TABLE 可以重命名临时表(TEMPORARY TABLE),rename TABLE 不可以。rename TABLE 可以在单个语句中重命名多个表,ALTER TABLE 只能重命名一个。虽然重命名操作快捷迅速,但实际生产场景中,对于表的重命名还是要慎重考虑,也许你的重命名操作没问题,但后续对象之间的依赖调用可能出现问题。比如你将一个表 tb1 重命名为 new_tb1,若有视图及函数依赖 tb1 ,并且你没及时修改这些视图及函数的话,那么再次调用这些视图和函数就可能报错 tb1 不存在,因为在这些视图及函数的定义中,仍用的是 tb1 的名称。此外重命名表或视图后,要注意用户权限问题,如果有显式指定某个用户对该表的权限,则需要重新赋予对新表的权限。若表中存在外键等约束时,执行重命名操作也要格外小心,做好检查。
总结:
本篇文章主要介绍了重命名表的操作方法及注意事项,将本文的重点总结如下:
rename TABLE 语句和 ALTER TABLE 语句都可以对表进行重命名,二者稍有区别,更推荐用 rename TABLE 语句。重命名操作需要获取元数据锁,执行前要确保无活跃事务占用。通过重命名表,可以将一个表从一个数据库转移到另一个数据库中,间接实现重命名数据库。实际生产场景,重命名表要慎重考虑,特别是存在视图及函数依赖的。重命名操作执行完成后,要检查用户权限及相关依赖问题,及时将依赖关系中的表名改为新的表名。若表中存在触发器或外键等约束,重命名时要格外注意。重命名操作一般在秒级完成,若执行时间过长,请检查链接状态。错误:1000 SQLSTATE: HY000 (ER_HASHCHK) 消息:hashchk错误:1001 SQLSTATE: HY000 (ER_NISAMCHK) 消息:isamchk错误:10...
2024.11.15关注我「程序猿集锦」,获取更多分享。初始化实验环境明确需求查找重复的数据查找要保留的数据删除重复的数据方法一方法二方法三写法1写法2总结MySQL中经常会遇到重复的数据,那么当我们遇到重复的时候的时候...
2024.11.15截取字符串是多么多么常见的一个需求啊,三家数据库厂商所实现的方法相近,但是也不相同。首先登场的是O记的SUBSTR,在线文档地址:https://docs.oracle.com/cd/E11882_0...
2024.11.15关于MySQL索引相关的内容,一直是一个让人头疼的问题,尤其是对于初学者来说。笔者曾在很长一段时间内深陷其中,无法分清“覆盖索引,辅助索引,唯一索引,Hash索引,B-Tree索引……”到底是些什么东...
2024.11.15概述数据库的外键虽然能保证数据数据一致性和完整性,但是也一定程度地影响了数据更新的性能。在开发中,我们使用PowerDesigner建立物理数据模型时,为了结构的清晰,增加可读性,会创建表与表之间的关...
2024.11.14