文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQL数据库中XML数据如何使用

2024-04-02 19:55

关注

MySQL数据库中XML数据如何使用,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。


  使用--xml选项将数据导出为XML格式
  在MySQL 5.0之前的版本中,使用MySQL命令行客户端以XML格式导出数据时有诸多限制,执行一个命令或查询时使用--xml或-X选项告诉MySQL客户端将结果输出为XML数据,例如,下面的命令将输出所有以version开头的数据库变量。

C:>mysql -u <userid> -p<password> -e     "SHOW VARIABLES LIKE '%version%'" &ndash;-xml

  最终输出的XML包括下面的标准格式:
   整个数据集都包括在节点中;
   每一行对应一个节点;
   所有列包括在一个节点中;
   列名出处在name属性中;
   列值是一个文本节点。

双击代码全选
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24<?xml version="1.0"?><resultset statement="SHOW VARIABLES LIKE '%version%'"     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">   <row>         <field name="Variable_name">protocol_version</field>         <field name="Value">10</field>   </row>   <row>         <field name="Variable_name">version</field>         <field name="Value">5.1.30-community</field>   </row>   <row>         <field name="Variable_name">version_comment</field>         <field name="Value">MySQL Community Server (GPL)</field>   </row>   <row>         <field name="Variable_name">version_compile_machine</field>         <field name="Value">ia32</field>   </row>   <row>         <field name="Variable_name">version_compile_os</field>         <field name="Value">Win32</field>   </row></resultset>

  为了便于对比,下面给出上面的命令表格化输出结果。

双击代码全选
1 2 3 4 5 6 7 8 9+-------------------------+---------------------+| Variable_name             | Value                  |+-------------------------+---------------------+| protocol_version          | 10                     || version                     | 5.1.22-beta-debug   || version_comment           | Source distribution || version_compile_machine | x86_64                 || version_compile_os       | suse-linux-gnu        |+-------------------------+---------------------+

  同样的语法可以应用到SELECT语句中,在我以前的一篇文章“借助临时表让你的MySQL查询效率更高”中,最开始的查询中我就用logical_delete_indicator=0的记录填充client_citizenship临时表。

双击代码全选
1 2 3 4 5 6 7 8 9 10 11 12 13 14INSERT INTO client_citizenshipSELECT     cl.client_id,     cl.date_of_birth,     cl.gender,        cit.citizenship_id,     cit.country_code,     cit.primary_citizenshipFROM      temp_table_article.client AS cl,       temp_table_article.citizenship AS cit,       temp_table_article.client_citizenship_rel AS rel  WHERE   cl.client_id                 = rel.client_id AND     cit.citizenship_id           = rel.citizenship_idAND     cit.logical_delete_indicator = 0AND     cl.logical_delete_indicator  = 0;

  在这个临时表上执行“SELECT *”查询返回下面的记录:

双击代码全选
1 2 3client_id, date_of_birth, gender, citizenship_id, country_code, primary_citizenship2,         1944-01-15,    F,      4,              20,           02,         1944-01-15,    F,      7,              77,           1

  当我加上--xml选项后,“SELECT *”查询将返回下面的XML格式结果:

双击代码全选
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20<?xml version="1.0"?><resultset statement="SELECT * FROM client_citizenship"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">   <row>         <field name="client_id">2</field>         <field name="date_of_birth">1944-01-15</field>         <field name="gender">F</field>         <field name="citizenship_id">4</field>         <field name="country_code">20</field>         <field name="primary_citizenship">0</field>   </row>   <row>         <field name="client_id">2</field>         <field name="date_of_birth">1944-01-15</field>         <field name="gender">F</field>         <field name="citizenship_id">7</field>         <field name="country_code">77</field>         <field name="primary_citizenship">1</field>   </row></resultset>

  使用--xml选项的缺点是从关联的数据到XML的映射是固定的,因此无法修改输出。如果你想做某些字符串操作,可以去掉--xml选项,按你自己的方式生成XML代码。
  继续沿用前面的查询,我们再来看看如何修改输出的XML,使其符合下面的格式要求:

双击代码全选
1 2 3 4 5 6 7 8<client>         <client_id>2</client_id>         <date_of_birth>1944-01-15</date_of_birth>         <gender>F</gender>         <citizenship_id>7</citizenship_id>         <country_code>77</country_code>         <primary_citizenship>1</primary_citizenship>   </client>

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯