IT技术网www.itjs.cn

当前位置:首页 > 数据库 > MySQL > MySQL数据目录的表示

MySQL数据目录的表示

发布时间:2010-10-13 11:44 来源:未知

SHOW DATABASE语句可以位于MySQL数据目录中的目录名,类似的语句还有很多,下面就将为您介绍一些类似的MySQL数据目录相关语句,供您参考。

每个MySQL服务器管理的数据库有自己的数据库表,它是MySQL数据目录下的一个子目录,其名字与它表示的数据库相同。例如数据库my_db对应于数据库目录DATADIR/my_db。

这种表示允许多个数据库级的语句在其实现中十分简单。CREATE DATABASE db_name在MySQL数据目录中创建一个db_name空目录,具有只允许MySQL服务器用户(运行服务器的Unix用户)的属主和模式,这等价于下列手工在服务器主机上创建数据库:

%mkdir DATADIR/db_name

%chmod 700 DADADIR/db_name

用一个空目录表示一个新数据库的最简单方法与其它数据库甚至为一个空数据库创建大量的控制文件或系统文件正好相反。

DROP DATABASE语句实现同样简单。DROP DATABASE db_name删除数据库中的db_name目录和所有表文件,这几乎与下列命令一样:

%rm -rf DATADIR/db_name

(差别是服务器只删除具有已知用于表的后缀名的文件。如果你在数据库目录创建了其它文件。则服务器保留它们,而且目录本身不被删除。

SHOW DATABASE基本上不做什么,只是列出位于MySQL数据目录中的目录名。有些数据库系统保持一个主表,用于维护所有数据库,但在MySQL无此构件。由于赋予数据目录结构的简洁性,数据库列表隐含在数据目录的内容中,而且这样的表不必有额外的开销。