%Library.CollationGenerator
Class %Library.CollationGenerator [ System = 2 ]
This class implements expression generators for all collations.
A collation expression is used by code generators to tranform logical data values into values used by indices.
For example, you may wish that a query by name finds the same results for both "ELVIS" and "elvis". Using a case-insensitive index transformation, such as String, will accomplish this. If you want an exact match, use Exact.
Collations are specified via a property's COLLATION parameter. Every datatype has a default COLLATION value, which matches one of the methods of the %Collation class. The COLLATION parameter can be overwritten by an individual property or by a specific index definition.
Note that changing a property's COLLATION value will corrupt any index values currently stored for that property and will require you to manually repopulate the index.
Methods
CollationExpression
ClassMethod CollationExpression(collation As %String = "", %val As %String, parms As %String) As %String
This method generates the appropriate collation expression as requested by the parameters. collation =
AlphaUp Converts a logical value to upper case, strips all punctuation and white space (except for ',' and '?').
This method is included for compatability with earlier products; use String instead.
Exact Performs no transformation; the index value is exactly the logical value.
Minus Prepends a minus ('-') sign to the logical value.
This method is included for compatability with earlier products; you should not need it in new applications.
MVR MULTI VALUE Collation
Plus Prepends a plus ('+') sign to the logical value.
This method is included for compatability with earlier products; you should not need it in new applications.
Space Prepends a space (' ') character to the logical value.
This method is included for compatability with earlier products; you should not need it in new applications.
SqlString Prepends a space to force string collation and strips trailing whitespace.
This method is used to insure that strings are collated case-sensitively and that numeric string values are collated correctly.
SqlUpper Converts a logical value to upper case, strips trailing whitespace and prepends a space to force string collation.
This collation is used to insure that strings are collated case-insensitively and that numeric string values are collated correctly.
String Converts a logical value to upper case, strips all punctuation and white space (except for ',').
Truncate Performs no transformation; the index value is exactly the logical value. However, the value will be truncated to the length specified by the optional length argument. Truncate with no length is the same as Exact.
Upper Converts a logical value to upper case without removing any characters.
%val the expression being collated
parms collation parameters as expected by collation
IsValid
ClassMethod IsValid(collation As %RawString = "") [ CodeMode = expression ]
Nulls
ClassMethod Nulls(collation As %String = "", collationparms As %String = "") As %Boolean
CollateCodeGen
ClassMethod CollateCodeGen(val As %String, transSpec As %String = "", length As %String = "") As %String
Generate collation expression for COLLATE collation