现在的位置: 首页 > 数据库 > 正文

MySQL中使用XML数据过程是怎么样的

2020年05月07日 数据库 ⁄ 共 2045字 ⁄ 字号 评论关闭

  在MySQL中使用XML数据可以更好的管理数据,将所有数据进行了格式化,这个过程是怎么样的呢?下面学步园小编来讲解下MySQL中使用XML数据过程是怎么样的?

  MySQL中使用XML数据过程是怎么样的

  上面使用的方法最大的缺陷就是在代码中写死了要检索的行,这样很不灵活,下面我们使用一个存储过程来解决这个问题。

  MySqlDump

  有IgorRomanenko编写的MySqlDump客户端最初是一个备份程序,它可以备份数据库,或将一个数据库转移到另一个数据库(MySQL或其它数据库),它的这个备份过程其实是一个创建表,填充表的过程。此外,MySqlDump还可以生成CSV,XML或其它由分隔符控制的文该篇文章件。

  虽然不止一种执行MySqlDump的方法,但我想使用下面的语法:

  mysqldump--xmldatabasename[tables]

  你也可以使用标准的Unix/Dos方法输出到一个文件,如下面的命令将一个表转成一个XML文件:

  C:\>mysqldump--xmltemp_table_articleclient>c:\\sqldump.xml

  打开sqldump.xml看看,我们发现MySqlDump客户端包括了比--xml选项更多的信息,但它却是按每一行、字段名和值的方式输出的,MySqlDump将表结构和表数据单独输出。

  name="client">client_idType=int(10)unsignedNull=NO"Key=PRI"Extra=auto_increment/>Field="date_of_birth"Type="date"Null="YES"Key=""Extra=""/>11976-02-12M121944-01-15F031956-06-04M141938-11-19F0

  MySQL中使用XML数据过程是怎么样的

  我们使用这个工具创建XML数据结构的原因是已经有存储过程可以将MySqlDumpXML数据插入到表中,MySQL开发人员AlexanderBarkov编写了这样一个存储过程xmldump_load,这个存储过程可以从mysqldump--xml命令输出的XML文档中提取数据,并将提取到的数据插入到MySQL表的列中,下面是这个存储过程的全部代码。

  DELIMITER|DROPPROCEDUREIFEXISTSxmldump_load|CREATEPROCEDURExmldump_load(file_nameVARCHAR(128),database_nameVARCHAR(128),table_nameVARCHAR(128))BEGINDECLARExmlTEXT;DECLAREnrowsINT;DECLARErownumINTDEFAULT1;DECLAREncolsINT;DECLAREcolnumINTDEFAULT1;DECLAREins_listTEXTDEFAULT'';DECLAREval_listTEXTDEFAULT'';DECLAREtmpVARCHAR(255);#将XML文件的内容载入到字符串中SETxml=LOAD_FILE(file_name);#获得这个表中的数量SETnrows=ExtractValue(xml,'count(/mysqldump/database[@name=$database_name]/table_data[@name=$table_name]/row)');#获得这个表中的数量SETncols=ExtractValue(xml,'count(/mysqldump/database[@name=$database_name]/table_data[@name=$table_name]/row[1]/field)');#对于每一个WHILErownum<=nrowsDO#对于每一个(列)WHILEcolnum<=ncolsDOSETtmp=ExtractValue(xml,'/mysqldump/database[@name=$database_name]/table_data[@name=$table_name]/row[$rownum]/field[$colnum]/@name');SETins_list=CONCAT(ins_list,tmp,IF(colnum   仔细阅读代码你就会发现其实这个存储过程使用了我们前面使用到的工具,如LOAD_FILE()和ExtractValue()函数,它只不过增加了两个嵌套的While循环,遍历每一行和列。   下面说说导入sqldump.xml文件的步骤。首先须创建xmldump_load存储过程。   C:\>mysqldb_namemysqltemp_table_article

  你也可以使用source或\.命令从MySQL客户端载入存储过程。

  mysql>sourcec:xmldump_load.sql;ORmysql>\.c:xmldump_load.sql;

  这个存储过程接受下面三个输入参数:

  XML输入文件名目标数据库名要创建的表名

  我们还是以前面创建的sqldump.xml文件,数据库和表名为例。

  mysql>callxmldump_load('c:\sqldump.xml','client_info','client');

  这条命令将向client_info数据库client表中插入sqldump.xml文件中的内容。

  即将推出的新特性

  MySQL6.0可以接受新的SQL语句,6.0.3版本将提供LOADXML功能,直接导入XML文件,再也不用啥存储过程了,在写该篇文章的时候还是5.4Beta版本,因此还需耐心等候一段时间。

  以上就是关于“MySQL中使用XML数据过程是怎么样的”的内容,希望对大家有用。更多资讯请关注学步园。学步园,您学习IT技术的优质平台!

抱歉!评论已关闭.