第十六章 处理空字符串和 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

相关推荐
苏-言1 分钟前
Spring IOC实战指南:从零到一的构建过程
java·数据库·spring
Ljw...7 分钟前
索引(MySQL)
数据库·mysql·索引
J总裁的小芒果10 分钟前
Vue3 el-table 默认选中 传入的数组
前端·javascript·elementui·typescript
Lei_zhen9612 分钟前
记录一次electron-builder报错ENOENT: no such file or directory, rename xxxx的问题
前端·javascript·electron
咖喱鱼蛋15 分钟前
Electron一些概念理解
前端·javascript·electron
yqcoder16 分钟前
Vue3 + Vite + Electron + TS 项目构建
前端·javascript·vue.js
菠萝咕噜肉i21 分钟前
超详细:Redis分布式锁
数据库·redis·分布式·缓存·分布式锁
长风清留扬23 分钟前
一篇文章了解何为 “大数据治理“ 理论与实践
大数据·数据库·面试·数据治理
鑫宝Code33 分钟前
【React】React Router:深入理解前端路由的工作原理
前端·react.js·前端框架
OpsEye36 分钟前
MySQL 8.0.40版本自动升级异常的预警提示
数据库·mysql·数据库升级