作者:一截藏青线 | 来源:互联网 | 2023-05-18 16:05
这篇文章给大家介绍MySQL中使用XML数据过程是怎么样的,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
在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&#39;&#39;;DECLAREval_listTEXTDEFAULT&#39;&#39;;DECLAREtmpVARCHAR(255);#将XML文件的内容载入到字符串中SETxml=LOAD_FILE(file_name);#获得这个表中的数量SETnrows=ExtractValue(xml,&#39;count(/mysqldump/database[@name=$database_name]/table_data[@name=$table_name]/row)&#39;);#获得这个表中的数量SETncols=ExtractValue(xml,&#39;count(/mysqldump/database[@name=$database_name]/table_data[@name=$table_name]/row[1]/field)&#39;);#对于每一个WHILErownum<=nrowsDO#对于每一个(列)WHILEcolnum<=ncolsdosettmp=extractvalue(xml, name="$database_name]/table_data[@name=$table_name]/row[$rownum]/field[$colnum]/@name&#39;);SETins_list=CONCAT(ins_list,tmp,IF(colnum">mysqldb_namemysqltemp_table_article
你也可以使用source或\.命令从MySQL客户端载入存储过程。
mysql>sourcec:xmldump_load.sql;ORmysql>\.c:xmldump_load.sql;
这个存储过程接受下面三个输入参数:
XML输入文件名目标数据库名要创建的表名
我们还是以前面创建的sqldump.xml文件,数据库和表名为例。
mysql>callxmldump_load(&#39;c:\sqldump.xml&#39;,&#39;client_info&#39;,&#39;client&#39;);
这条命令将向client_info数据库client表中插入sqldump.xml文件中的内容。
即将推出的新特性
MySQL6.0可以接受新的SQL语句,6.0.3版本将提供LOADXML功能,直接导入XML文件,再也不用啥存储过程了,在写该篇文章的时候还是5.4Beta版本,因此还需耐心等候一段时间。
关于MySQL中使用XML数据过程是怎么样的就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。