前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >临时全局变量和IRISTEMP数据库

临时全局变量和IRISTEMP数据库

作者头像
用户7741497
发布2022-06-09 12:14:02
2030
发布2022-06-09 12:14:02
举报
文章被收录于专栏:hml_知识记录

临时全局变量和IRISTEMP数据库

对于某些操作,可能需要全局变量的功能,而不需要无限期保存数据。例如,可能希望使用全局对某些不需要存储到磁盘的数据进行排序。对于这些操作,InterSystems IRIS提供了临时全局机制。该机制的工作方式如下:

  • 对于应用程序名称空间,可以定义一个全局映射,以便将具有特定命名约定的全局变量映射到IRISTEMP数据库,该数据库是一个特殊的数据库,如下所述。

例如,可以定义一个全局映射,以便将名称为^AcmeTemp*的所有全局变量映射到IRISTEMP数据库。

  • 当代码需要临时存储数据并再次读取它时,代码将向使用该命名约定的全局变量写入数据,并从全局变量读取数据。

例如,要保存值,代码可能会执行以下操作:

代码语言:javascript
复制
 set ^AcmeTempOrderApp("sortedarray")=some value

然后,稍后代码可能会执行以下操作:

代码语言:javascript
复制
 set somevariable = ^AcmeTempOrderApp("sortedarray")

通过使用临时全局变量,可以利用IRISTEMP数据库没有日志记录这一事实。因为数据库没有日记记录,所以使用该数据库的操作不会产生日记文件。日志文件可能会变得很大,并可能导致空间问题。但是,请注意以下几点:

不能回滚修改IRISTEMP数据库中的全局变量的任何事务;此行为特定于IRISTEMP。如果需要通过事务管理临时工作,请不要使用IRISTEMP中的全局变量来实现此目的。

请注意,仅对不需要保存的工作使用IRISTEMP

定义临时全局变量的映射

要定义临时全局变量的映射,请执行以下操作:

  1. 选择一个命名约定,并确保所有开发人员都知道这一点。请注意以下几点:
  • 考虑是要有多个临时全局变量还是要少一些具有多个节点的临时全局变量。与读取或写入相同数量的独立全局变量相比,InterSystems IRIS更容易高效地读取或写入同一全局变量中的不同节点。这种效率差异对于少数全局变量来说可以忽略不计,但当有数百个独立的全局变量时,效率差异就非常明显。
  • 如果计划在多个名称空间中使用相同的全局映射,那么设计一个系统,使一个名称空间中的工作不会干扰另一个名称空间中的工作。例如,可以使用命名空间名称作为全局变量中的下标。
  • 类似地,即使在一个命名空间内,也要设计一个系统,使代码的每个部分在同一全局中使用不同的全局或不同的下标,以避免干扰。
  • 请勿使用系统保留的全局名称。
  1. 在管理门户中,导航到命名空间页面(System Administration > Configuration > System Configuration > Namespaces)。
  2. 在应用程序命名空间所在的行中,单击Global Mappings。
  3. 在全局映射页面中,单击新建全局映射。
  4. 对于全局数据库位置,选择IRISTEMP
  5. 对于全局名称,输入以星号(*)结尾的名称。不要包括名称的第一个插入符号。

例如: AcmeTemp*

此映射会导致名称以AcmeTemp*开头的所有全局变量映射到IRISTEMP数据库。

  1. 单击OK。

注意:>> 显示在新映射行的第一列中,表示已打开映射进行编辑。

  1. 要保存映射以便InterSystems IRIS使用它们,请单击保存更改。

IRISTEMP的系统使用

请注意,InterSystems使用临时全局变量作为临时空间,例如,在执行某些查询(用于排序、分组、计算聚合等)期间用作临时索引。

IRISTEMP中包含的一些系统全局变量包括:

  • ^IRIS.Temp*
  • ^mtemp*

永远不要更改这些全局变量中的任何一个。

本文系转载,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文系转载前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 临时全局变量和IRISTEMP数据库
  • 定义临时全局变量的映射
  • IRISTEMP的系统使用
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档