Alter database的处理过程没有像alter table那么恐怖,处理逻辑还是比较清晰的。先整理如下:
1、查看数据库名是否有效调用check_db_name()(table.cc:2876)查看数据库名是否有效,其中调用check_table_name()(table.cc:2904)函数。check_table_name这个函数名有些误导,实际是检查数据库名是否合法。
2、查看是否有权修改调用check_access()(sql_parse.cc:4715)检查数据库是否存在,用户对数据库是否有权限修改。
3、数据库修改调用mysql_alter_db()(sql_db.cc:685)对数据库进行修改。修改前,调用lock_schema_name()(lock.cc:767)函数,获取schema的互斥锁。调用write_db_opt()(sql_db.cc:313)函数,重建db.opt文件,db.opt文件记录的内容是默认字符集的内容。之后写binlog。通过以上分析可知,Alter database的操作的业务逻辑较为简单,但是功能也较简单,alter database选项仅仅可以修改默认charset和默认的collation。MySQL内部临时表策略MySQL审计插件安装使用说明文档相关资讯 MySQL基础
- MySQL因为区分大小写而引起找不到 (09/08/2012 20:12:21)
- MySQL 执行计划解读 (09/07/2012 06:18:14)
- MySQL审计插件安装使用说明文档-- (08/09/2012 08:57:10)
| - MySQL 版本选择 (09/07/2012 06:18:58)
- MySQL Internal 笔记 (09/01/2012 16:34:19)
- MySQL的“[Warning] Invalid (old? (08/09/2012 08:55:01)
|
本文评论 查看全部评论 (0)