对于某些操作,可能需要全局变量的功能,而不需要无限期保存数据。例如,可能希望使用全局对某些不需要存储到磁盘的数据进行排序。对于这些操作,InterSystems IRIS
提供了临时全局机制。该机制的工作方式如下:
IRISTEMP
数据库,该数据库是一个特殊的数据库,如下所述。例如,可以定义一个全局映射,以便将名称为^AcmeTemp*
的所有全局变量映射到IRISTEMP
数据库。
例如,要保存值,代码可能会执行以下操作:
set ^AcmeTempOrderApp("sortedarray")=some value
然后,稍后代码可能会执行以下操作:
set somevariable = ^AcmeTempOrderApp("sortedarray")
通过使用临时全局变量,可以利用IRISTEMP
数据库没有日志记录这一事实。因为数据库没有日记记录,所以使用该数据库的操作不会产生日记文件。日志文件可能会变得很大,并可能导致空间问题。但是,请注意以下几点:
不能回滚修改IRISTEMP
数据库中的全局变量的任何事务;此行为特定于IRISTEMP
。如果需要通过事务管理临时工作,请不要使用IRISTEMP
中的全局变量来实现此目的。
请注意,仅对不需要保存的工作使用IRISTEMP
。
要定义临时全局变量的映射,请执行以下操作:
InterSystems IRIS
更容易高效地读取或写入同一全局变量中的不同节点。这种效率差异对于少数全局变量来说可以忽略不计,但当有数百个独立的全局变量时,效率差异就非常明显。IRISTEMP
。*
)结尾的名称。不要包括名称的第一个插入符号。例如: AcmeTemp*
此映射会导致名称以AcmeTemp*
开头的所有全局变量映射到IRISTEMP
数据库。
注意:>> 显示在新映射行的第一列中,表示已打开映射进行编辑。
请注意,InterSystems使用临时全局变量作为临时空间,例如,在执行某些查询(用于排序、分组、计算聚合等)期间用作临时索引。
IRISTEMP中包含的一些系统全局变量包括:
^IRIS.Temp*
^mtemp*
永远不要更改这些全局变量中的任何一个。
本文系转载,前往查看
如有侵权,请联系 cloudcommunity@tencent.com 删除。
本文系转载,前往查看
如有侵权,请联系 cloudcommunity@tencent.com 删除。