Welcome 微信登录

首页 / 数据库 / MySQL / MySQL数据库Alter database 处理逻辑

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)
表情: 姓名: 字数