>  기사  >  데이터 베이스  >  MySQL数据库Alter database 处理逻辑

MySQL数据库Alter database 处理逻辑

WBOY
WBOY원래의
2016-06-07 17:18:121472검색

Alter database的处理过程没有像alter table那么恐怖,处理逻辑还是比较清晰的。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。

linux

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.