0

0

Informatica Developer Tool中的XML映射

畫卷琴夢

畫卷琴夢

发布时间:2026-02-09 14:22:33

|

120人浏览过

|

来源于php中文网

原创

Informatica中XML映射需先导入Schema并启用层级结构,字段带路径且须匹配命名空间;解析失败多因Schema与实例不一致;生成嵌套XML用XML Generator并严格分组排序;格式化缩进仅在Session中开启XML Output Format。

informatica developer tool中的xml映射

XML映射在Informatica Developer Tool里怎么建

不能直接在Developer Tool(IDQ或IICS的Web界面)里“新建XML映射”,因为XML源/目标必须先定义为XML Schema对象,再作为SourceTarget拖入Mapping。开发者常误以为能像Flat File一样直接连字段,结果找不到XML节点——根本原因是Schema没导入或没解析成功。

  • 先用Developer Tool → Connections → XML Connection配置XML Schema路径(支持本地文件、HTTP URL或Repository内存储的XSD)
  • 右键该Connection → Import XML Schema,确保勾选Generate hierarchical structure,否则只生成根元素,子节点全丢
  • 导入后,在Objects → SourcesTargets里会出现对应XML对象,双击可展开层级树,确认elementattribute都已识别
  • 拖入Mapping时,字段名默认带路径(如/Order/Customer/Name),不是扁平化字段,不能直接连到普通String端口

XML源读取时字段值为空或报错XML Parser failed: unexpected end of document

这通常不是数据问题,而是Schema与实际XML实例不匹配。Informatica严格按XSD校验结构,哪怕多一个空格、少一个xmlns声明,解析就中断。

  • 检查XML实例是否声明了命名空间(xmlns="http://xxx"),若Schema没定义targetNamespace,必须在导入时勾选Ignore namespace during import
  • 确保XML文件编码与Schema中encoding一致(常见坑:UTF-8 with BOM被当成非法字符)
  • 如果XML含CDATA块,Schema里对应xs:string字段需在Mapping中显式设置Enable CDATA parsing = Yes(在Source Qualifier的Properties → XML Options里)
  • 大文件慎用Parse on Read:默认开启会导致整棵XML树加载进内存,超10MB易OOM;可改用Streaming Parse(需在Source定义时勾选Enable streaming

怎么把关系型数据写成嵌套XML(比如Orders → OrderItems)

XML Generator转换器,不是靠Target连接线堆叠。它必须接在AggregatorSorter之后,且输入流要按父节点分组排序(如先按OrderID排序,再按ItemID排序)。

MyBatis3.2.3帮助文档 中文CHM版
MyBatis3.2.3帮助文档 中文CHM版

MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架。MyBatis 消除 了几乎所有的 JDBC 代码和参数的手工设置以及结果集的检索。MyBatis 使用简单的 XML 或注解用于配置和原始映射,将接口和 Java 的 POJOs(Plan Old Java Objects,普通的 Java 对象)映射成数据库中的记录。有需要的朋友可以下载看看

下载
  • 在Mapping中加XML Generator,双击打开,点击Add Root Element → 输入根名(如Orders
  • 右键根节点 → Add Child Element,设为Order,并绑定Group By字段(如OrderID
  • 继续加Order的子节点CustomerName(绑定字段)、OrderItems(再设一层Group By,如OrderID, ItemID
  • XML Generator输出是binary端口,必须连到Target DefinitionXML类型字段;若Target是File,需在Session中设置Output Type = XML且指定XML Output Format = Formatted才可读

为什么XML Target写出来的文件没有换行缩进,全是单行

因为Informatica默认输出紧凑XML(no whitespace)。即使Schema里写了,也不影响运行时格式。

  • 唯一控制方式是在Session配置里:进入Config Object → Properties → XML Output,将Format XML output设为Yes
  • 注意:开启后性能下降约20%–40%,尤其嵌套深、节点多时;生产环境建议仅调试阶段启用
  • 缩进宽度固定为2空格,不可调;换行符是\n(Linux风格),Windows环境打开可能显示为乱码,需用Notepad++切换EOL模式
  • 如果Target是Database中的CLOB字段,Format XML output无效——数据库只存原始字节,格式化必须由应用层处理
/* 示例:XML Generator关键配置片段(非代码,仅示意逻辑) */
Root Element: Orders
├─ Group By: none
├─ Child Element: Order
│  ├─ Group By: OrderID
│  ├─ Child Element: CustomerName → map from PORT_CUSTOMER_NAME
│  └─ Child Element: OrderItems
│     ├─ Group By: OrderID, ItemID
│     └─ Child Element: ProductCode → map from PORT_PRODUCT_CODE
└─ (No further grouping)

XML层级深度超过5层、或含混合内容(mixed content)时,XML Generator容易生成结构错位的输出,这时得拆成多个Mapping分段生成,再用Shell脚本拼接——不是功能限制,是设计上对复杂文档模型的支持薄弱。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

646

2023.08.02

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

864

2023.07.31

python中的format是什么意思
python中的format是什么意思

python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

442

2024.06.27

session失效的原因
session失效的原因

session失效的原因有会话超时、会话数量限制、会话完整性检查、服务器重启、浏览器或设备问题等等。详细介绍:1、会话超时:服务器为Session设置了一个默认的超时时间,当用户在一段时间内没有与服务器交互时,Session将自动失效;2、会话数量限制:服务器为每个用户的Session数量设置了一个限制,当用户创建的Session数量超过这个限制时,最新的会覆盖最早的等等。

323

2023.10.17

session失效解决方法
session失效解决方法

session失效通常是由于 session 的生存时间过期或者服务器关闭导致的。其解决办法:1、延长session的生存时间;2、使用持久化存储;3、使用cookie;4、异步更新session;5、使用会话管理中间件。

767

2023.10.18

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

95

2025.08.19

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1921

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2100

2024.08.01

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

129

2026.02.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 8.7万人学习

Git 教程
Git 教程

共21课时 | 3.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号