亲爱的社区开发者们:
本周进入 InterSystems 编程大奖赛 的投票时间! 来为你心目中基于InterSystems IRIS而构建的最佳方案投票吧!
🔥 点击投票 投票入口 🔥
如何投票?有哪些最新信息值得了解一下?
亲爱的社区开发者们:
本周进入 InterSystems 编程大奖赛 的投票时间! 来为你心目中基于InterSystems IRIS而构建的最佳方案投票吧!
🔥 点击投票 投票入口 🔥
如何投票?有哪些最新信息值得了解一下?
InterSystems SQL命令(也称为SQL语句)以关键字开头,后跟一个或多个参数。其中一些参数可能是子句或函数,由它们自己的关键字标识。
;)终止。否则,InterSystems SQL命令不需要或接受分号命令终止符。在InterSystems SQL中指定分号命令终止符会导致SQLCODE -25错误。 TSQL的InterSystemsIRIS®数据平台实现(Transact-SQL)接受但不需要分号命令终止符。在将SQL代码导入Inter Systems SQL时,会去除分号命令终止符。InterSystems SQL关键字包括命令名称,函数名称,谓词条件名称,数据类型名称,字段约束,优化选项和特殊变量。
提供锁名信息。
^$|nspace|LOCK(lock_name,info_type,pid)
^$|nspace|L(lock_name,info_type,pid)
|nspace|或[nspace] [nspace]可选-扩展SSVN引用,显式名称空间名称或隐含名称空间。必须计算为带引号的字符串,该字符串括在方括号([“nspace”])或竖线()中。命名空间名称不区分大小写;它们以大写字母存储和显示。pid对其他info_type关键字没有影响。^$LOCK结构化系统变量返回有关当前命名空间或本地系统上指定命名空间中的锁的信息。可以通过两种方式使用:
大家好,
正如我在上一个帖子分片评估(第 1 部分)中所承诺的,我继续研究了分片数量的影响。
为了完成概览,我还添加了以下实例:
在 WIN (Server 2012 R2) 8 核上
- Cache for Windows (x86-64) 2016.2.2 - 12 GB 全局缓冲区
- IRIS for Windows (x86-64) 2018.1.1 - 400 MB 全局缓冲区,无分片
在 LINUX (Ubuntu 16.04 LTS) 2 核上
- IRIS for UNIX (Ubuntu Server LTS for x86-64) 2018.1.1 400MB 全局缓冲区
- 无分片、2 个分片、3 个分片、4 个分片。
我使用的表有 2650 万条记录,并且在所有具有相同索引的实例上均相同
查询:
- SELECT $LISTLENGTH($LISTFROMSTRING(LIST(<property>))) FROM ... WHERE ... %STARTSWITH <value>
这里使用了 2 个不同的值,结果为 47000 和 19000 次命中。
我将其称为简单查询 S47 和 S19
- SELECT $LISTLENGTH($LISTFROMSTRING(LIST(<property1>))) FROM .
大家好!
InterSystems IRIS 有一个名为 Interoperability(互操作性)的菜单。
它提供了轻松创建系统集成(适配器、记录映射、BPM、数据转换等)的机制,因此可以轻松连接不同的系统。
数据中继过程中可以包括各种操作,例如:为了连接没有正常连接的系统,可以根据目标系统的规范来接收(或发送)数据。 此外,在发送数据之前,可以从其他系统获取和添加信息。 还可以从数据库(IRIS 等)获取和更新信息。
在本系列文章中,我们将讨论以下主题,同时查看 示例代码 以帮助您了解工作原理以及在系统中集成互操作性时需要进行哪种开发。
首先,我介绍一下我们将在本系列文章中使用的案例研究。
某公司运营着一个购物网站,他们正在更改产品信息的显示顺序以配合季节变化。
但是,有些商品无论季节如何都能卖得很好,而有些商品在意料之外的时间卖出,这不符合当前的显示顺序更改规则,
因此,我们研究了按照当天的温度而不是季节来更改显示顺序的可能性。 调查购买产品时的温度变得非常必要。
由于可以使用外部 Web API 来查询天气信息,因此我们计划收集购买时的天气信息,并将其记录在后面的审核数据库中。
案例非常简单,但您需要使用“外部 Web API”来收集信息,并且需要将获得的信息和购买信息结合起来记录在数据库中。
InterSystems IRIS 元素周期表

PDF 版本:
GIT 源:
InterSystems IRIS 是一个具有许多功能的数据平台。 这些功能和相关的 IRIS 主题都体现在元素周期表中。
这是一个第三方写的在 IRIS 2020.1 和 Caché 2018.1.3 上工作的代码示例
不会与新版本保持同步
也不会获得 InterSystems 支持提供的服务!
Caché/Ensemble/IRIS 中的 Global 通常在 SQL 访问中是不可见的
本示例将展示如何克服此限制。
Global 扫描和切片
这是一个在 IRIS 2020.1 和 Caché 2018.1.3 上工作的代码示例
不会与新版本保持同步
也不会获得 InterSystems 提供的支持服务!
大多数情况下,默认存储使用的 global 只有 1 个表示 IDKEY 的下标级别。 对于索引 global,可能有 2 个或更多下标级别。
数组、父子关系或扩展了基础数据类的持久化类 是具有更多下标级别的示例。 但所有这些 global 都非常统一。
InterSystems API Manager (IAM) 版本1.5已正式发布。
IAM容器,包括从原有IAM版本升级的所有相关工件, 现在可以在 WRC 软件发布网址 组件区下载。
该版本的小版本号是 IAM 1.5.0.9-4。
InterSystems API Manager 1.5 使管理API通讯、与你的环境集成、加载API用户更加容易。它包含很多新特性,包括:
这个版本基于Kong Enterprise version 1.5.0.9。之前的IAM版本包括一个贴牌版本的Kong Enterprise, 在本版本中的Kong Enterprise不再贴牌。 这个变化让我们可以更快的节奏带给您新的版本,并更有效地利用Kong提供的文档和其它资源。
请在 这里 查看IAM 1.5 的文档。这个文档仅说明IAM特殊的元素。产品中的文档链接直接打开Kong Enterprise的文档。
从IAM 0.34-1 升级需要通过3个中间版本累积升级,在 文档中有详细的说明。
IAM 仅以OCI (Open Container Initiative) 或 Docker 容器格式发放。
这是我们团队参加的第一届InterStstems编程竞赛! 快来看看投票给我们!
超额预订管理系统结合了酒店业的独特条件,例如房价,订购渠道,客户需求等。 本系统使用机器学习算法(例如:KNN / ES-RNN ...)来准确预测酒店的每日未入住和入住率,并进一步与收益结合以找到最佳的最大客房销售量,从而精准增加酒店的边际收益。
最近完成了针对IRIS医疗版2020.1版本的性能及可扩展性基准测试,重点关注HL7v2的互操作性。本文介绍了在各种工作负载下观察到的吞吐量,并提供了IRIS医疗版用作HL7v2消息传输互操作性引擎时的系统常规配置和调整准则。
基准测试模拟了与实际环境接近的工作负载(详细信息请参见“工作负载说明和方法”部分)。本次测试的工作负载包括HL7v2患者管理(ADT)和生命体征结果(ORU)数据,并包含数据内容转换和路由。
IRIS医疗版2020.1版本可以表明,采用第二代Intel®Xeon®可扩展处理器和Intel®Optane™SSD DC P4800X系列SSD存储的商用服务器,每天的持续消息吞吐量超过23亿条(入站和出站总量),与此前的Ensemble 2017.1 HL7v2吞吐量基准测试相比,扩展性提高了一倍多。
|
大数据的 5 个 V 与 InterSystems IRIS
|
|
| Velocity(速度):水平和垂直节点扩展传递出的弹性速度 实现者:分布式内存缓存、分布式处理、分片和多模型架构 https://www.intersystems.com/isc-resources/wp-content/uploads/sites/24/… 和 https://learning.intersystems.com/course/view.php?id=1254&ssoPass=1 | |
| Value(价值):Analytics 和 AI产生的指数数据价值实现:BI、NLP、ML、AutoML 和多模型架构 https://docs.intersystems.com/irislatest/csp/docbook/Doc.View.cls?KEY=S… 和 https://docs.intersystems.com/irislatest/csp/docbook/DocBook.UI.Page.cls? | |
.jpeg)
不少客户问我关于从Cache迁移到IRIS的问题。为什么要迁移到IRIS?Cache是优秀的,稳定的,有很好的性能,为什么要迁移到IRIS呢?这些客户是对的,但在过去几年,数字化转型提出了不少新问题、新需求和新挑战,客户需要更灵活、更完整、更前瞻的解决方案,InterSystems公司很有远见地洞察到了这一点,推出了IRIS。
一句话,IRIS是一套数据平台解决方案,它帮助客户和合作伙伴为迎接数字化转型的挑战提供了充足的弹药。
2020 年最佳 Open Exchange 开发者和应用程序! 大家好,
2020 年是优秀应用程序丰收的一年!
将近 400 个应用程序已上传到 InterSystems Open Exchange! 200 多个应用程序在 2020 年上传到我们的应用程序库!
我们很高兴向大家介绍最佳 Open Exchange 开发者和下载量最大的应用程序,这些应用程序绝对值得一试!
让我们仔细看一下我们的英雄们和卓越的应用程序:
.png)
提供系统间IRIS进程(JOB)信息。
^$JOB(job_number)
^$J(job_number)
job_number 输入ObjectScript命令时创建的系统特定OBJ编号。每个活动的InterSystems IRIS进程都有一个唯一的作业号。登录到系统会启动一个作业。在UNIX®系统上,作业号是调用InterSystems IRIS时启动的子进程的PID。JOB_NUMBER必须指定为整数;不支持十六进制值。可以将^$JOB结构化系统变量用作、$ORDER和函数的参数,以获取有关本地InterSystems IRIS系统上是否存在InterSystems IRIS作业的信息。
以下示例显示如何将用作、和函数的参数。
作为的参数返回一个整数值,该值指示指定的作业是否作为节点存在于中。下表显示了可以返回的整数值。
| Value | Meaning |
|---|---|
| 0 | JOB不存在 |
| 1 | JOB存在 |
以下示例测试系统间IRIS进程是否存在。
DHC-APP>SET x=$JOB
DHC-APP>WRITE !,$DATA(^$JOB(x))
1
变量设置为当前进程的作业号(例如:4294219937)。写入操作返回布尔值1,表示此进程存在。
提供有关全局变量和进程私有全局变量的信息。
^$|nspace|GLOBAL(global_name)
^$|nspace|G(global_name)
^$||GLOBAL(global_name)
^$||G(global_name)
|nspace| 或 [nspace] - 可选-扩展SSVN引用,可以是显式名称空间名称,也可以是隐含名称空间。必须计算为带引号的字符串,该字符串括在方括号([“nspace”])或竖线()中。命名空间名称不区分大小写;它们以大写字母存储和显示。^||a。可以将^$GLOBAL用作、$ORDER和函数的参数,以返回有关当前名称空间(默认名称空间)或指定名称空间中是否存在全局变量的信息。还可以使用返回有关存在进程私有全局变量的信息。
可以使用获取有关所有命名空间中是否存在进程私有全局变量的信息。可以将进程专用全局的查找指定为或。
例如,要获取有关进程私有全局及其后代的信息,可以指定
包含一个字符串,描述do命令后面的InterSystems IRIS.line的当前版本。
$ZVERSION
$ZV
$ZVERSION包含一个字符串,该字符串显示当前运行的InterSystems IRIS®Data Platform实例的版本。
以下示例返回$ZVERSION字符串:
DHC-APP>WRITE $ZVERSION
Cache for Windows (x86-64) 2016.2 (Build 736U) Fri Sep 30 2016 11:46:02 EDT
此字符串包括InterSystems IRIS安装的类型(产品和平台,包括CPU类型)、版本号(2018.1)、该版本中的内部版本号(内部版本号中的“U”表示UNICODE以及创建此版本的InterSystems IRIS的日期和时间。是东部标准时间(美国东部的时区),“EDT”是东部夏令时
通过调用类方法可以返回相同的信息,如下所示:
DHC-APP>WRITE $SYSTEM.Version.GetVersion()
Cache for Windows (x86-64) 2016.2 (Build 736U) Fri Sep 30 2016 11:46:02 EDT
以通过调用其他
大家好!
InterSystems开发者社区中文版正在招募版主,以更好地推动中文社区建设,期待每一位开发者的积极参与,共同打造一个高效沟通的技术社区!
欢迎点击报名(或扫描下方二维码),审核通过后,我们会与您详细沟通版主权益及义务。
.png)
包含当前错误陷阱处理程序的名称。
$ZTRAP
$ZT
$ZTRAP包含当前错误陷阱处理程序的行标签名和/或例程名。有三种方法可以设置$ZTRAP:
SET $ZTRAP=“location”SET $ZTRAP=“*location”SET $ZTRAP=“^%ET” or “^%ETN”在这里,位置可以指定为标签(当前例程中的行标签)、(指定外部例程的开始)或(指定外部例程中的指定标签)。
然而,不能用于程序块。过程块中的不能用于转到过程体之外的位置;过程块中的$ZTRAP只能引用该过程块中的一个位置。
使用设置命令,可以将位置指定为带引号的字符串。
$ZTRAP设置为或.尝试这样做将导致错误。在过程中,将设置为私有标签名,但是
包含格林威治子午线的时区偏移量。
$ZTIMEZONE
$ZTZ
$ZTIMEZONE可以通过两种方式使用:
$ZTIMEZONE包含从格林威治子午线偏移的时区(以分钟为单位)。 (格林威治子午线包括整个英国和爱尔兰。)此偏移量表示为-1440到1440范围内的有符号整数。格林威治以西的时区指定为正数;格林威治东部的时区指定为负数。 (时区必须以分钟为单位,因为并非所有时区都以小时为单位。)默认情况下,$ZTIMEZONE初始化为计算机操作系统设置的时区。
注意:$ZTIMEZONE将本地时间调整为固定的偏移量。它不适应夏令时或其他当地时间的变化。 InterSystems IRIS从基础操作系统获取本地时间,该操作系统将本地时间变体应用于为该计算机配置的位置。因此,使用调整的本地时间将从配置的语言环境中获取其本地时间变化,而不是在$ZTIMEZONE中指定的时区。
使用格林威治子午线()的时区计数来计算UTC时间。它与当地格林威治时间不同。格林威治标准时间(GMT)一词可能令人困惑;格林威治的当地时间与冬季的UTC相同。在夏季,它与UTC的差异为一小时。这是因为应用了称为英国夏令时的本地时间变体。
对于使用
包含协调世界时间格式的当前日期和时间。
$ZTIMESTAMP
$ZTS
$ZTIMESTAMP包含协调的通用时间值形式的当前日期和时间。这是世界范围内的时间和日期标准;此值很可能与当地的时间(和日期)值不同。
$ZTIMESTAMP将日期和时间表示为以下格式的字符串:
ddddd,sssss.fff
其中ddddd是一个整数,指定自1840年12月31日起的天数;是一个整数,指定自当天午夜以来的秒数,fff是一个可变的数字,指定小数秒。这种格式类似于,只是不包含分数秒。
假设当前日期和时间(世界协调时)如下:
2018-02-22 15:17:27.984
当时,的值为:
64701,55047.984
$ZTIMESTAMP报告协调世界时(UTC),它独立于时区。因此,提供了一个跨时区的统一时间戳。这可能不同于本地时间值和本地日期值。
时间值是一个十进制数值,以秒及其分数为单位计算时间。分数秒的位数可能从零到九不等,具体取决于计算机时钟的精度。在视窗系统上,小数精度是三位小数;在UNIX系统上,它是六位十进制数字。在此小数部分中抑制尾随零或尾随小数点。请注意,在午夜后的第一秒内,秒表示为(例如,);这个数字不是ObjectScript规范形式(例如,),这会影响这些值的字符串排序顺序。
包含进程的最大可用内存。
$ZSTORAGE
$ZS
$ZSTORAGE包含JOB的进程私有内存的最大内存量(以为单位)。此内存可用于局部变量、堆栈和其他表。此内存限制不包括例程目标代码的空间。此内存根据需要分配给进程,例如在分配数组时。
一旦将此内存分配给进程,通常在该进程退出之前不会释放它。但是,当大量内存被使用(例如,大于32MB)然后被释放时,系统间IRIS会尝试在可能的情况下将释放的内存释放回操作系统。
还可以使用设置最大内存大小。例如,以下语句将作业的最大进程专用内存设置为:
SET $ZSTORAGE=524288
更改会更改$STORAGE特殊变量的初始值,该变量包含进程的当前可用内存(以字节为单位)。
的最大值为。默认值为。的最小值为。值大于最大值或小于最小值会自动默认为最大值或最小值。设置为整数值;InterSystems IRIS截断任何小数部分(如果指定)。
可以通过更改最大每进程内存(KB)系统配置设置来更改默认值。在管理门户中,依次选择System Administration、Configuration、Systtem Configuration、Memory和Startup。
大家好!
以下是 InterSystems编程大奖赛 的技术奖励,这些奖励会让您在投票中获得加分。
大家可能已经听说过,我们近期推出了InterSystems API管理器 (以下简称IAM)。InterSystems IRIS数据平台™新增了一项功能,支持用户监视、控制和管理IT基础架构中基于Web的API间通信。
在本文中,我将向大家展示如何设置IAM,并重点介绍IAM中可用的一些功能。InterSystems API管理器可提供你所需的一切功能。
包含当前全局变量global引用。
$ZREFERENCE
$ZR
$ZREFERENCE包含上次全局引用的名称和下标。这就是所谓裸指针。
注意:最后一个全局引用是最近访问的全局节点。通常,这是对全局的最新显式引用。但是,某些命令可能在内部使用$ORDER函数遍历全局下标(命令就是一个例子),或者它们可能在内部引用其他全局脚本。发生这种情况时,$ZREFERENCE包含上次访问的全局节点,该节点可能不是为命令指定的全局节点。
最后一个全局引用可以是全局()或进程专用全局()。$ZREFERENCE以最初用于该变量的形式返回进程专用全局前缀,而不管随后对该变量使用哪个进程专用全局前缀。在接下来的描述中,单词指的是这两种类型的变量。
最后一个全局引用是命令或函数最近引用的全局。由于ObjectScript按从左到右的顺序执行操作,因此最后一个全局引用始终是最右侧的全局引用。当命令或函数使用多个参数时,最右侧参数中指定的全局参数是最后一个全局引用。当参数包含多个全局引用时,最右侧指定的全局引用是最后一个全局引用。即使使用圆括号来定义操作顺序,从左到右的严格顺序也是正确的。
当发出显式全局引用时,InterSystems IRIS会更新
包含当前进程的父进程的ID。
$ZPARENT
$ZP
$ZPARENT包含使用JOB命令创建当前进程的父进程的。如果当前进程不是使用命令创建的,则包含0(零)。
不能使用SET命令修改此特殊变量。尝试这样做会导致错误。
包含的值。
$ZPI
$zpi包含数值常量到小数点后18位的值()。
该值经常用于三角函数,例如正弦函数。
包含读取顺序文件期间的当前文件位置。
包含顺序文件读取期间的当前文件位置。如果没有正在进行的顺序文件读取,则包含0(零)。
当打开文件进行顺序读取时,每次从该设备读取都会将设置为文件中下一次读取的位置。值是读取、读取或读取结束时的实际文件偏移量(以字节为单位)。用户在读取多字节字符集时必须适当小心。
可以使用函数设置当前文件位置。不能使用命令修改此特殊变量。尝试这样做会导致错误。
包含下一个全局节点的值。
$ZORDER
$ZO
$ZORDER包含当前全局引用之后的下一个全局节点的值(在$QUERY序列中,而不是序列中)。如果没有下一个全局节点,访问将导致错误,指示成功访问的最后一个全局节点。
不能使用命令修改此特殊变量。尝试这样做会导致错误。
下面的示例使用WHILE循环重复调用以遍历一系列下标节点:
/// d ##class(PHA.TEST.SpecialVariables).ZORDER()
ClassMethod ZORDER()
{
SET ^||a="groceries"
SET ^||a(1)="fruit"
SET ^||a(1,1)="apples"
SET ^||a(1,2)="oranges"
SET ^||a(3)="nuts"
SET ^||a(3,1)="peanuts"
SET ^||a(2)="vegetables"
SET ^||a(2,1)="lettuce"
SET ^||a(2,2)="tomatoes"
SET ^||a(2,1,1)="iceberg"
SET ^||a(2,1,2)="romaine"
SET $ZERROR="unset"
WRITE !,"last referenced: ",^||a(1,1)
WHILE $ZERROR="unset" {
WRITE !,$ZORDER
}
QUIT
}
包含当前命名空间名称。
$ZNSPACE
$ZNSPACE包含当前命名空间的名称。通过设置$ZNSPACE,可以更改当前名称空间。
要获取当前命名空间名称,请执行以下操作:
DHC-APP>SET ns=$ZNSPACE
DHC-APP>WRITE ns
DHC-APP
还可以通过调用类的方法来获取当前命名空间的名称,如下所示:
DHC-APP>SET ns=$SYSTEM.SYS.NameSpace()
DHC-APP>WRITE ns
DHC-APP
可以使用类的Existes()方法测试命名空间是否已定义,如下所示:
DHC-APP>WRITE ##class(%SYS.Namespace).Exists("USER")
1
DHC-APP>WRITE ##class(%SYS.Namespace).Exists("LOSER")
0
对于UNIX®系统,默认命名空间建立为系统配置选项。对于Windows系统,它是使用命令行启动选项设置的。
命名空间名称不区分大小写。InterSystems IRIS始终以全大写字母显示显式名称空间名称,以全小写字母显示隐含的名称空间名称。
要获取指定进程的命名空间名称,请使用类的方法,如下例所示:
可以使用命令、SET $NAMESPACE、