在MySQL中使用XML数据可以将数据进行格式化以更好的管理数据。
有IgorRomanenko编写的MySqlDump客户端最初是一个备份程序,它可以备份数据库,或将一个数据库转移到另一个数据库(MySQL或其它数据库),它的这个备份过程其实是一个创建表,填充表的过程。此外,MySqlDump还可以生成CSV,XML或其它由分隔符控制的文本文件。
虽然不止一种执行MySqlDump的方法,但我想使用下面的语法:
我们使用这个工具创建XML数据结构的原因是已经有存储过程可以将MySqlDumpXML数据插入到表中,MySQL开发人员AlexanderBarkov编写了这样一个存储过程xmldump_load,这个存储过程可以从mysqldump--xml命令输出的XML文档中提取数据,并将提取到的数据插入到MySQL表的列中,下面是这个存储过程的全部代码。
仔细阅读代码你就会发现其实这个存储过程使用了我们前面使用到的工具,如LOAD_FILE()和ExtractValue()函数,它只不过增加了两个嵌套的While循环,遍历每一行和列。
即将推出的新特性
MySQL6.0可以接受新的SQL语句,6.0.3版本将提供LOADXML功能,直接导入XML文件,再也不用啥存储过程了,在写本文的时候还是5.4Beta版本,因此还需耐心等候一段时间。