My SQL数据目录结构
时间:2007-12-23 来源:不详 作者:迈克DB
假如上述方式失败,你可以用find寻找数据库文件,下列命令寻找“.frm”文件,它是任何MySQL安装的一部分:
%find/-name".frm"-print
在下文各例中,用DATADIR表示MySQL数据目录位置。
2、数据目录结构
MySQL数据目录包含了服务器治理的所有数据目录,这些文件被组织成一个树状结构,通过利用Unix或Windows文件系统的层次结构直接实现。
每个数据库对应于数据目录下的一个目录。
在一个数据库中的表对应于数据目录下的文件。
数据目录也包含由服务器产生的几个状态文件,如日志文件。这些文件提供了关于服务器操作的重要信息。对治理非凡在出了问题而试图确定问题原因时很有价值。例如,假如某个特定查询杀死服务器,你可以通过检查日志文件判别捣乱的查询。
2.1MySQL服务器怎样提供对数据的访问
在数据目录下的一切由一个单独的实体-MySQL服务器mysqld治理,客户程序绝不直接操作数据。相反,服务器提供数据可访问的切入点,它是客户程序与它们想使用的数据之间的中介。
当服务器启动时,假如有需要,它打开日志文件,然后通过监听网络连接位数据目录呈现一个网络接口。要访问数据,客户程序建立对服务器的一个连接,然后以MySQL查询传输请求来执行希望的操作。服务器执行每一个操作并将结果发回用户。服务器是多线程的并能服务多个同时的客户连接。然而,因为修改操作一个执行一个,实际效果是顺序化请求,以使两个客户决不能在同一时刻改变同一记录。
织梦好,好织梦
在正常的情况下,让服务器作为数据库访问的唯一仲裁者提供了避免可从同时访问数据库表的多个进程的破坏的保证。治理员应该知道有时服务器没有对数据目录的独裁控制。
当你在一个单个数据目录上运行多个服务器。一般倪云新一个服务器治理主机上的所有数据库,但是有可能运行多个服务器。假如这完成提供对多个独立数据目录的访问,没有相互影响的问题,但哟也能启动多个服务器并指向同一个目录。一般地,这不是一个好主意。假如你试图这样,最好是你的系统提供良好的文件锁定功能,否则服务器将不能正确协作。假如你将多个服务器同时写入日志文件,你也冒着你的日志文件称为混乱的根源的风险。
在你运行isamchk和myisamchk时。isamchk和myisamchk实用程序用于表的维护、诊错和修复,就想你想的那样,因为这些程序可以修改表内容,答应它们与服务器正在操作的同时对表操作,这样能导致表损坏。理解如何限制这种相互影响是很重要的,这样你不会损坏你的表。
2.2数据目表示
每个MySQL服务器治理的数据库有自己的数据库表,它是数据目录下的一个子目录,其名字与它表示的数据库相同。例如数据库my_db对应于数据库目录DATADIR/my_db。
这种表示答应多个数据库级的语句在其实现中十分简单。CREATEDATABASEdb_name在数据目录中创建一个db_name空目录,具有只答应MySQL服务器用户(运行服务器的Unix用户)的属主和模式,这等价于下列手工在服务器主机上创建数据库:
内容来自dedecms
%mkdirDATADIR/db_name
%chmod700DADADIR/db_name
用一个空目录表示一个新数据库的最简单方法与其它数据库甚至为一个空数据库创建大量的控制文件或系统文件正好相反。
DROPDATABASE语句实现同样简单。DROPDATABASEdb_name删除数据库中的db_name目录和所有表文件,这几乎与下列命令一样:
%rm-rfDATADIR/db_name
(差别是服务器只删除具有已知用于表的后缀名的文件。假如你在数据库目录创建了其它文件。则服务器保留它们,而且目录本身不被删除。
SHOWDATABASE基本上不做什么,只是列出位于数据目录中的目录名。有些数据库系统保持一个主表,用于维护所有数据库,但在MySQL无此构件。由于赋予数据目录结构的简洁性,数据库列表隐含在数据目录的内容中,而且这样的表不必有额外的开销。
上一篇:SQL 的一些核心语句 下一篇:T-SQL 查询中使用的函数之系统函数
文章评论
共有位Admini5网友发表了评论 查看完整内容