Chapter 7 Cache JSON %JSON quick reference

%JSONQuick reference

This section provides a quick reference to the %JSON methods, properties, and parameters discussed in this chapter.

%JSON.Adaptormethods

These methods provide the ability to serialize from AND to JSON.

%JSONExport()

%JSONExport() serializes jSON-enabled classes into JSON documents and writes them to the current device.

   method %JSONExport(%mappingName As %String = "") as %Status
Copy the code
  • %mappingName(Optional)- The name of the mapping to be used for export. The base mapping is represented by “” and is the default mapping.

%JSONExportToStream()

%JSONExportToStream() serializes the jSON-enabled class into a JSON document and writes it to the stream.

   method %JSONExportToStream(ByRef export As %Stream.Object, 
      %mappingName As %String = "") as %Status
Copy the code
  • export– An export stream containing serialized JSON documents.
  • %mappingName(Optional)- The name of the mapping to be used for export. The basic mapping is defined by""Represents, and is the default mapping.

%JSONExportToString()

% json.adaptor.%JSONExportToString() serializes a JSON-enabled class into a JSON document and returns it as a string.

   method %JSONExportToString(ByRef %export As %String, 
      %mappingName As %String = "") as %Status
Copy the code
  • Export– A string containing the serialized JSON document.
  • %mappingNameOptional)- The name of the mapping to be used for export. The basic mapping is defined by""Represents, and is the default mapping.

%JSONImport()

% json.adaptor.%JSONImport() imports JSON or dynamic entity input into this object.

   method %JSONImport(input, %mappingName As %String = "") as %Status
Copy the code
  • input-JSON can be a string, stream, or string%DynamicAbstractObjectThe subclass.
  • %mappingName(Optional)- The name of the mapping to be used for import. The basic mapping is defined by""Represents, and is the default mapping.

%JSONNew()

%JSONNew() gets an instance of a JSON-enabled class. You can override this method to perform custom processing (such as initializing an object instance) before returning an instance of this class. However, this method should not be called directly from user code.

   classmethod %JSONNew(dynamicObject As %DynamicObject, 
      containerOref As %RegisteredObject = "") as %RegisteredObject
Copy the code
  • dynamicObject– A dynamic entity with a value to assign to a new object.
  • containerOref(Optional)- From%JSONImport()Contains the object instance when called.

% json. Adaptor class and property parameters

You can specify parameters for classes or individual attributes unless otherwise specified. As a class parameter, it specifies the default value of the corresponding attribute parameter. As a property parameter, it specifies a value that overrides the default value.

%JSONENABLED

Enable the generation of property transformation methods.

  parameter %JSONENABLED = 1;
Copy the code
  • 1-(default) generates JSON enabled methods.
  • 0- The method generator does not generate Runnable methods.

%JSONFIELDNAME (properties only)

Sets the string to be used as the field name in the JSON content.

  parameter %JSONFIELDNAME
Copy the code

By default, attribute names are used.

%JSONIGNOREINVALIDFIELD

Controls handling of unexpected fields in JSON input.

  parameter %JSONIGNOREINVALIDFIELD = 0;
Copy the code
  • 0-(default) Treat an unexpected field as an error.
  • 1- The unexpected field will be ignored.

%JSONIGNORENULL

Specifies how to store an empty string for string attributes. This parameter applies only to true strings (determined by XSDTYPE =”string” and JSONTYPE=”string”).

  parameter %JSONIGNORENULL = 0;
Copy the code
  • 0-(default) Empty strings in JSON input are stored as$char(0).$char(0)As a string""Write to JSON. Missing fields in the JSON input are always stored as""And according to%JSONNULLParameters,""Always output to JSON.
  • 1- Both empty strings and missing JSON fields are used""Input, and""and$char(0)All as field values""The output.

%JSONINCLUDE (properties only)

Specifies whether this property is included in the JSON output or input.

  parameter %JSONINCLUDE = "inout"
Copy the code
  • "inout"(Default)- included in both input and output.
  • "outputonly"– Ignore this attribute as input.
  • "inputOnly"– Ignore this property as output.
  • "None"– This attribute is never included.

%JSONNULL

Controls the processing of unspecified attributes.

  parameter %JSONNULL = 0;
Copy the code
  • 0 -(default) Skip fields corresponding to unspecified attributes during export.
  • 1 – Unspecified attributes are exported as null values.

%JSONREFERENCE

Specifies how to project an object reference to a JSON field.

  parameter %JSONREFERENCE = "OBJECT";
Copy the code
  • "OBJECT"-(default) Attributes of the referenced class used to represent the referenced object.
  • "ID"– Persistent or serial classIDUsed to represent references.
  • "OID"— persistent or serialOIDUsed to represent references.

The OID is projected to JSON in the form of classname and ID. -“GUID” – The GUID of the persistent class is used to indicate the reference.

% json. ForMatter method and properties

The % json. ForMatter class can be used to format a JSON string, stream, or object of the %DynamicAbstractObject subclass.

Format()

% json.formatter.format () formats a JSON document with the specified indentation and writes it to the current device.

method Format(input) as %Status
Copy the code
  • input-JSON can be a string, stream, or string%DynamicAbstractObjectThe subclass.

FormatToStream()

% JSON. The Formatter. FormatToStream () using the specified indentation formatted JSON document and write it down.

method FormatToStream(input, ByRef export As %Stream.Object) as %Status
Copy the code
  • input-JSON can be a string, stream, or string%DynamicAbstractObjectThe subclass.
  • export– Formatted JSON stream.

FormatToString()

% JSON. The Formatter. FormatToString () using the specified indentation formatted JSON document and writes it to a string, or classes will enable the JSON serialization for JSON documents returned as a string.

method FormatToString(input, ByRef export As %String = "") as %Status
Copy the code
  • input-JSON can be a string, stream, or string%DynamicAbstractObjectThe subclass.
  • export(Optional)- Formatted JSON stream.

Indent

The % json.formatter. Indent property specifies whether the JSON output should be Indent. The default is true.

property Indent as %Boolean [ InitialExpression = 1 ];
Copy the code

IndentChars

% JSON. The Formatter. IndentChars property specifies when enabled indent for each level of indentation sequences of characters. The default is a space.

property IndentChars as %String [ InitialExpression = "" ];
Copy the code

LineTerminator

% JSON. The Formatter. LineTerminator attribute specifies the indentation to end each line of the character sequence. The default is $char(13,10).


property LineTerminator as %String [ InitialExpression = $char(13.10)];Copy the code
/// d ##class(PHA.TEST.Xml).Obj2FormatterJson()
ClassMethod Obj2FormatterJson(a)
{
	s event = ##class(Model.Event%).New(a)s event.Name = "yx"
	s location = ##class(Model.Location%).New(a)s location.City = "tianjin"
	s location.Country = "china"
	s event.Location = location
	d event.%JSONExportToString(.jsonEvent)
	s formatter = ##class(%JSON.Formatter%).New(a)s formatter.Indent = 1
	s formatter.IndentChars = "-"
	//s formatter.LineTerminator = "!"
	d formatter.Format(jsonEvent)
}
Copy the code
DHC-APP>d ##class(PHA.TEST.Xml).Obj2FormatterJson(a){-"Name":"yx",
 - "Location":{
 -  - "City":"tianjin", -- -"Country":"china"
 - }
}
DHC-APP>d ##class(PHA.TEST.Xml).Obj2FormatterJson(a){! - "Name":"yx",! - "Location": {! - -"City":"tianjin",! -  - "Country":"china"! - }!}
Copy the code