第十六章 处理空字符串和 Null 值

文章目录

  • [第十六章 处理空字符串和 Null 值](#第十六章 处理空字符串和 Null 值)
  • [空字符串和 `Null` 值的默认映射](#空字符串和 Null 值的默认映射)
  • 导出值
  • 控制空元素的形式

第十六章 处理空字符串和 Null 值

类和属性参数

  • XMLUSEEMPTYELEMENT

  • XMLIGNORENULL

  • XMLNILNOOBJECT

  • XMLNIL

空字符串和 Null 值的默认映射

下表总结了空字符串和 null 值的默认 XML 映射。请注意,XML 映射与 SQL 映射类似,此处也显示了 SQL 映射以进行比较。

空字符串和 Null 值的默认 SQLXML 映射

InterSystems IRIS Value Default Projection to XML Projection to SQL
$char(0) 空元素或属性 SQL 空字符串
"" No projection SQL NULL value

导出值

下表列出了对于作为元素映射到 XML 的属性,可以将空字符串和 null 值从支持 XML 的对象导出到 XML 文档的方法:

导出作为元素映射到 XML 的属性的空字符串和 Null

Details of XML-Enabled Class Property equals "" Property equals $char(0)
类指定 XMLIGNORENULLXMLNIL 的默认值 导出的 XML 文档不包含与此属性对应的元素 导出的文档包含与此属性对应的空元素;参见本小节
类指定 XMLIGNORENULL=1 导出的文档包含与此属性对应的空元素;参见本小节 导出的文档包含与此属性对应的空元素;参见本小节
类指定 XMLNIL=1(并且 XMLIGNORENULL 不是 1 导出的文档包含与此属性对应的空元素,并且此空元素指定 xsi:nil="true" 导出的文档包含与此属性对应的空元素;参见本小节

映射为属性的属性的详细信息类似:

导出作为属性投影到 XML 的属性的空字符串和 Null

Details of XML-Enabled Class Property equals "" Property equals $char(0)
类指定此表中描述的参数的默认值 导出的 XML 文档不包含与此属性对应的属性 导出的文档包含与此属性对应的空属性
XMLIGNORENULL=1 导出的文档包含与此属性对应的空属性。例如:PropName="" 导出的文档包含与此属性对应的空属性
XMLNIL=1(并且 XMLIGNORENULL 不是 1)) 导出的 XML 文档不包含与此属性对应的属性(与默认场景相同) 导出的文档包含与此属性对应的空属性

控制空元素的形式

默认情况下, IRIS 写入带有开始标记和结束标记的空元素。例如:

xml 复制代码
<PropName></PropName>

可以改为让 IRIS 写入一个自关闭空元素(这是等效的)。例如:

xml 复制代码
<PropName />

为此,请将 XMLUSEMPTYELEMENT 类参数指定为 1。此参数的默认值是 0

相关推荐
炫饭第一名11 小时前
速通Canvas指北🦮——基础入门篇
前端·javascript·程序员
NineData11 小时前
数据库迁移总踩坑?用 NineData 迁移评估,提前识别所有兼容性风险
数据库·程序员·云计算
王晓枫11 小时前
flutter接入三方库运行报错:Error running pod install
前端·flutter
符方昊11 小时前
React 19 对比 React 16 新特性解析
前端·react.js
ssshooter11 小时前
又被 Safari 差异坑了:textContent 拿到的值居然没换行?
前端
曲折11 小时前
Cesium-气象要素PNG色斑图叠加
前端·cesium
Forever7_11 小时前
Electron 淘汰!新的桌面端框架 更强大、更轻量化
前端·vue.js
Angelial12 小时前
Vue3 嵌套路由 KeepAlive:动态缓存与反向配置方案
前端·vue.js
jiayu12 小时前
Angular学习笔记24:Angular 响应式表单 FormArray 与 FormGroup 相互嵌套
前端
jiayu12 小时前
Angular6学习笔记13:HTTP(3)
前端