#InterSystems IRIS

1 フォロワー · 1.3K 投稿

InterSystems IRISは総合データプラットフォームです

    InterSystems IRISは、企業にとって最も価値のある資産(データ)の取得、共有、理解、そしてデータに基づく行動のために必要なすべてのものを提供します。

    完全なプラットフォームである InterSystems IRIS は、複数の開発技術を統合する必要がありません。より少ないコードで開発が可能で、そのアプリケーションは、システムリソース、メンテナンスなども少なくて済みます。

記事 Toshihiko Minamoto · 2月 22, 2022 14m read

最初のパートでは、IMAP プロトコルコマンドについて簡単に説明しました。このパートでは、IRIS を使用してこれらのコマンドを実装し、独自の IMAP クライアントを作成してみましょう!

IRIS Email フレームワーク

IRIS プラットフォームには電子メールを操作するためのデフォルトのインターフェースとクラスがあります。 これらのアーティファクトは元々 POP3 実装用に設計されていますが、 これらのインターフェースとクラスを IMAP クライアントの実装に使用して拡張できないということではありません。 それでは、このことについて説明しましょう。

  • %Net.FetchMailProtocol: メールを取得するための基本クラスです。 IMAP クライアントはこれを拡張しています。
  • %Net.MailMessage: MIME メッセージです。 %Net.MailMessagePart. を拡張します。
  • %Net.MailMessagePart: マルチパートメッセージの MIME メッセージをカプセル化します。 このクラスにはそれ自体の配列があり、メッセージのサブパートをツリーで表現できるようにします。
  • %Net.MIMEReader: このユーティリティは、メッセージの MIME コンテンツを解析するメソッドで、%Net.MIMEPart インスタンスを生成します。
  • 0
    0 167
    質問 Yuji Ohata · 2月 17, 2022

    こんにちは、皆さま。
    業務でIRISを用いて開発を行っている者です。

    現在、共通のIRIS環境を複数個所に用意するため、
    インストール・マニフェストを利用した環境構築の仕組みを作成しております。
    https://docs.intersystems.com/iris20211/csp/docbookj/DocBook.UI.Page.cl…

    Interoperabilityを有効にしたNMSPについて、
    管理ポータル上から作成すると、資格情報を保持する用のSECONDARYのローカルデータベースが
    自動で作成されるように認識しております。
    https://docs.intersystems.com/iris20211/csp/docbookj/DocBook.UI.Page.cl…

    しかし、マニフェスト経由で作成した場合にはそれが作成されていません


    ■作成しているマニフェスト

    2
    0 206
    質問 Akio Hashimoto · 2月 3, 2022

    皆さん
    こんにちは。

    最近ではVSCodeでIRISのプログラミングを行っている方も多いと思います。
    クラスメソッドなんかをコーディングし、実行してエラーとなった場合に、以下のようなエラーメッセージが取得できると思います。

    > <UNDEFINED> zNewMethod+32^ClassName.1
    

    これは、NewMethodというメソッド内の32行目でUNDEFINEDが発生した事を指していますが、これは実際にはClassName.clsのNewMethod内の32行目ではなく、ClassName.1というルーチン(int)のzNewMethodでの32行目を示しています。
    .clsから生成されるintは空行が削られたり、複数ルーチンに分割されたりしますので、実際のClassName.clsを開いてNewMethodの32行目を見ても実際のエラー箇所では無い場合があります。
    VSCodeで開発をしていると、これが結構面倒なのですが、エラーメッセージに出力される行番号を .clsや、.mac 上での行番号に変える方法があれば教えて頂きたく、よろしくお願い致します。

    2
    0 556
    記事 Toshihiko Minamoto · 2月 16, 2022 8m read

    この記事では、InterSystems IRIS プラットフォームを使用して基本的な IMAP クライアントを記述する方法を説明します。 はじめに IMAP の概要を確認してから、本題の IMAP コマンドとクライアント実装について説明します。 最後に、IRIS 相互運用性アプリケーションでこの IMAP クライアントを簡単に使用します。

    この記事では IMAP を詳しく説明していません。 詳細な情報については、この記事のリソースをご覧ください。

    IMAP の概要

    ユーザーは IMAP(Internet Message Access Protocol)を使ってメールを取得できます。 IMAP は 1980 年代に Marc Crispin によって提唱されました。以来、このプロトコルは RFC 3501 として公開され、改訂されています。 この記事の執筆時点での最新バージョンは、IMAP4rev1 です。

    0
    0 391
    InterSystems公式 Toshihiko Minamoto · 2月 15, 2022

    更新: 開発者プレビュー・リリース3が公開されました

    これはインターシステムズにとって初めての開発者プレビュー・リリースであるため、これらがどのようなものであるかを説明します。 開発者プレビュー・プログラムは、従来のIRISプレビュー・プログラムを強化したもので、約2週間ごとにリリースされ、準備が整うと機能が追加されます。 これにより、機能や機能拡張に関するフィードバックを得ることができます。 2022.1に向けた機能拡張のリストは以下の通りです。これらは最初の開発者プレビューには含まれていません。 これらは今後数週間のうちに公開される予定です。

    一般公開に先立ち、皆様からのご意見をお待ちしています。より良い製品を一緒に作っていくために、開発者コミュニティを通じてフィードバックを共有してください。

    InterSystems IRIS Data Platform 2022.1 は、エクステンデッド・メンテナンス (EM) リリースです。2022.1 には、前回の EM リリースである 2021.1 以降、継続的デリバリー (CD) リリースである 2021.2 で追加された多くの重要な新機能や拡張機能が追加されています。これらの機能強化の概要については、2021.2 のリリース・ノートをご参照ください。

    0
    0 200
    記事 Megumi Kakechi · 2月 13, 2022 2m read

    これは、InterSystems FAQサイトの記事です。
    各プロセスが消費しているメモリの内容は、Windowsリソースモニタの項目のワーキングセット、共有可能、プライベートで確認できます。

    これらの内容は以下になります。

    ワーキングセット プロセスが使用する物理メモリです。
             ワーキングセット(プライベート)とワーキングセット(共有可能)との合計です。 

    共有可能               プロセスが使用する物理メモリ内で他のプロセスと共有可能なメモリです。

    プライベート       プロセスが使用する物理メモリ内で他のプロセスと共有不可能なメモリです。


    例えば、以下のようにメモリを使用しているプロセスがある場合、ほとんどは共有メモリになっているといえます。

    ワーキングセット 5,341,472 = 共有可能 5,328,664 + プライベート12,808 (kb)


    プロセスがアクセスする共有メモリは、データベースキャッシュおよびルーチンキャッシュで使用されているメモリ領域になります。

    プロセスが大量にグローバルへのアクセスを行うと、データベースキャッシュへのアクセス量も多くなり、メモリ使用量の共有可能の数値が大きくなります。
    (最大でデータベースキャッシュサイズまで大きくなります)

    0
    0 308
    記事 Toshihiko Minamoto · 2月 9, 2022 2m read

    これは、前回の「DockerマイクロサーバーとしてのIRIS Native APIを使用するWebSocketクライアントJS」のフォローアップです。

    すべてのピースが1つのDockerイメージにまとめられたため、インストールがはるかに簡単になりました。
    作業が楽になります。 ただしもちろん、マイクロサービスの原則はわかりにくくなくなっています。
    オールインワンのバンドルパッケージであるため、 コンパクトになっています。

    0
    0 293
    InterSystems公式 Toshihiko Minamoto · 2月 9, 2022

    インターシステムズは、2018年からInterSystems IRISで2ストリームのリリースサイクルを採用しています(開始時のお知らせをご覧ください)。  

    • Continuous delivery (CD) リリース —このリリースは、新機能を迅速に提供し、継続的に更新され、新機能を直ちに利用するアプリケーションの開発、およびデプロイに最適です。
    • Extended maintenance (EM) リリース — このリリースは、CDリリースよりも頻度は低いですが、メンテナンス・リリースの安定性を提供します。新機能をいち早く利用することよりも、メンテナンスリリースでの修正が容易であることが重要な大規模エンタープライズアプリケーションに最適です。

    このアプローチについては非常に好意的なフィードバックをいただいており、人々は「鈍行列車(slow train)」と「快速列車(fast train)」という言葉を使うようになりました。 EMリリースは、大規模なオンプレミスの顧客基盤をs持つお客様やパートナーに好まれる「鈍行列車」です。 CDリリースは、最新かつ最高の機能を求めるお客様やパートナーに好まれる「快速列車」です。

    0
    0 297
    お知らせ Mihoko Iijima · 1月 28, 2022

    開発者の皆さん、こんにちは!

    次の InterSystems プログラミングコンテストのお題が発表されました!次は、Python です!

    🏆 InterSystems Python Contest 🏆

    応募期間:2022年2月7日~20日

    💰 賞金総額: $10K 💰 + さらに賞品を用意予定です!


    1
    0 277
    お知らせ Mihoko Iijima · 2月 7, 2022

    開発者の皆さん、こんにちは!

    InterSystems Python コンテスト 2022 のテクノロジーボーナスについてご案内します。

    以下のテクノロジを使いコンテストにご応募いただくと、ボーナス点を獲得できます!

    • Embedded Python - 4
    • Python Native API  - 3
    • Python Pex - 3
    • ObjectScript を使用しない - 5
    • アンケート への回答- 2
    • Docker コンテナの使用 - 2 
    • ZPM パッケージによるデプロイ - 2
    • オンラインデモ公開 - 2
    • コミュニティに記事を投稿する - 2
    • コミュニティに2つ目の記事を投稿する - 1
    • YouTubeでビデオを公開する - 3

    詳細は以下の通りです。

    0
    0 130
    InterSystems公式 Maki Hashizawa · 2月 7, 2022

    開発者のみなさん、こんにちは。

    インターシステムズジャパンは、3/8(火)~ 3/9日(水)に、オンラインカンファレンス「InterSystems Japan Virtual Summit 2022」を開催致します。

    "Innovation in Data - データによるデジタル変革の推進" をテーマに、DX推進に不可欠な健全なデータの提供とデータプラットフォームの最新情報をお届け致します。ご参加をお待ちしております!

    ⚡️ 現在、事前登録受付中 ⚡️

       

    【InterSystems Japan Virtual Summit 2022 開催概要】

    ■テーマ:Innovation in Data - データによるデジタル変革の推進

    ■開催日時:2022年3月8日(火)・9日(水)13:30 - 15:45 (予定)

    ■開催形式:オンラインライブ配信

    ■参加:無料(事前登録制)

    お申込み・詳細はこちらから

    《ゲストスピーカー講演》

      「物流業界における真の課題を解決― 運ばない物流を支えるロジスティクス変革システム「Jobs」のご紹介」

       株式会社 ビーイングホールディングス 事業開発本部 部長 北川 徹也 様

      「情報連携基盤を活用した医療情報二次利用の経験」

      岩手医科大学 総合情報センター センター長 田中 良一 様

    《技術セッション》

    0
    0 257
    記事 Mihoko Iijima · 2月 4, 2022 7m read

    開発者の皆さん、Python好きの皆さん、こんにちは!

    ドキュメントをみながら IRIS 2021.2 に追加された Embedded Python を試してみました!

    IRIS にログインしてるのに Pythonシェルに切り替えできて Python のコードが書けたり、Python で import iris するだけで SQL を実行できたりグローバルを操作できるので、おぉ!✨という感じです。

    ぜひ、みなさんも体感してみてください!

    では早速。

    まず、IRISにログインします。Windows ならターミナルを開きます。Windows 以外は以下実行します。

    IRIS のインストール方法を確認されたい方は、【はじめての InterSystems IRIS】セルフラーニングビデオ:基本その1:InterSystems IRIS Community Edition をインストールしてみよう!をチェックしてみてください!

    iris session iris
    0
    1 858
    記事 Toshihiko Minamoto · 2月 3, 2022 12m read

    キーワード: Pandasデータフレーム、IRIS、Python、JDBS

    目的

    PandasデータフレームはEDA(探索的データ分析)に一般的に使用されるツールです。 MLタスクは通常、データをもう少し理解することから始まります。 先週、私はKaggleにあるこちらのCovid19データセットを試していました。 基本的に、このデータは1925件の遭遇の行と231列で構成されており、タスクは、患者(1つ以上の遭遇レコードにリンク)がICUに入室するかどうかを予測するものです。 つまりこれは、いつものようにpandas.DataFrameを使用して、まず簡単にデータを確認する、通常の分類タスクです。  

    0
    0 371
    質問 Akio Hashimoto · 2月 1, 2022

    Windows端末でCachéやIRIS等を開発環境として使っています。

    Windows11での動作状況について、インターシステムズからの正式な対応はまだのようですので、

    下記のバージョンで既にインストールをされている方が居られれば、状況などを教えて頂けないでしょうか。

    特に問題無く動いていますでしょうか?

    ・Caché 2017.1

    ・IRIS for Health 2019.1

    この他のバージョンについても情報が御座いましたらよろしくお願い致します。

    2
    0 425
    質問 Yuji Ohata · 1月 26, 2022

    こんにちは、皆さま。
    業務でIRISを用いて開発を行っている者です。

    TIMESTAMP型のデータを持つテーブルの扱いについて教えてください。

    現在Ens_Util.Logを参照するシステムを開発しようとしております。
    このテーブルの中にTimeLoggedというTIMESTAMP型のデータがあるのですが、
    それをSELECTした際、CASTの有無で表示されるデータに差異が出ます。

    SELECT
        DATE(TimeLogged),
        CAST(TimeLogged AS TIME),
        TimeLogged
    FROM
        Ens_Util.Log

    Expression_1|Expression_2|TimeLogged         |
    ------------+------------+-------------------+
      2022-01-25|    15:00:01|2022-01-26 00:00:01|
      2022-01-25|    15:00:01|2022-01-26 00:00:01|
      2022-01-25|    15:00:01|2022-01-26 00:00:01|

    確認する限り9時間の差があるため、UTC時刻との時差が出ているものと考えていますが、ここで何点か疑問があります。

    8
    0 338
    記事 Minoru Horita · 2月 2, 2022 6m read

    開発者の皆さん、こんにちは!

    最近リリースされた InterSystems IRIS 2021.2 の目玉機能のひとつが Embedded Pythonです。Embedded Pythonは、PythonのランタイムをIRISに組み込むことによって、IRISのメソッドをPythonで記述したり、PythonのコードからIRISのクラスにアクセスしたりなどなど、IRISのObjectScriptとPythonとで相互に呼び出しを行なえる機能です。

    しかも、Pythonのランタイムを埋め込んでいるため、ネットワークのオーバーヘッドがなく、パフォーマンスへの影響は最小限です。

    IRISのプログラマの方には、Pythonの豊富なライブラリをストレスなく利用して頂けます。

    Pythonのプログラマの方には、ObjectScriptを学ぶことなく、IRISの高速なデータベースやインターオペラビリティ機能などをストレスなく活用して頂けます。

    今回の記事では、Embedded Pythonの機能をほんの一部だけ紹介します。

    メソッドをPythonで書く

    次のコードは、日付を表す文字列を2つ渡して、2つの日付の間の日数を返すメソッドです。

    0
    0 1317
    記事 Toshihiko Minamoto · 2月 1, 2022 5m read
    これはIRIS 2020.2で動作するコーディングの例です 
    最新バージョンとは同期していません。
    また、InterSystemsのサポートによるサービスはありません

    動作中のデモを確認できるデモビデオを以下で公開しています。https://youtu.be/dSV-0RJ5Olg

    皆さんこんにちは
    完全に新しいIRISイメージと**たった4行**のDockerコマンドを使って実行するイメージを使ってマイクロサービスのデモを行いましょう。 
    2020年6月1日 - rcc

    すべてのパーツを1つのコンテナイメージにまとめたコンパクトなオールインワンバージョンが公開されました。
    詳細はこちら: IRIS-NativeAPI-Nodejs-compact
    2020年5月24日 - rcc

    Dockerを使った簡易インストールを追加しました。コンテキストを参照
    2020年5月25日 - rcc

    Linux & Windowsに最適な検証済みの強化スクリプトはこちら
    https://github.com/rcemper/WSockClientMicroSV/blob/master/READMEwindows.MD
    2020年5月26日 - rcc

    このデモは、Caché用にすでに存在するNode.jsに基づくWebSocketクライアントを再設計したものです。 主に以下のような変更点があります。

    • 新しいIRIS Native API for Node.jsの使用。特にグローバル配列を操作する場合
    • 直接トリガーされたクライアントからサーバー設計への変更
    • マイクロサービス/マイクロサーバーの例として、結果を別のdockerイメージに配置
    • マイクロサービスの実行を制御するための単純なインターフェースをIRISに追加
    0
    0 335
    InterSystems公式 Yoichi Miyashita · 1月 31, 2022

    インターシステムズは、InterSystems IRIS data platform、InterSystems IRIS for Health、HealthShare Health Connect の バージョン 2021.2 をリリースしました。

    【新機能のご紹介】
    InterSystems IRIS data platform 2021.2 には、以下の新機能が含まれます。

    (1) アプリケーション および インターフェース開発者向け機能
    ・Embedded Python
    ・Python を利用した Interoperability プロダクション
    ・Visual Studio Code の ObjectScript 拡張機能
    ・必要最小限のコードで SQL 実行を可能にする、新しいビジネス・サービスおよび ビジネス・オペレーション

    (2) 分析 および AI 機能
    ・CSV や JDBC 経由のデータを効率よくロードする新しい SQL LOAD コマンド
    ・Adaptive Analytics の機能強化

    (3) クラウド および システム運用者向け機能
    ・InterSystems IRIS アプリケーションからクラウド・サービスへのより簡単な接続や利用を容易にする、新しいクラウド・コネクタ
    ・IKO による Kubernetes リソース管理機能の向上

    0
    0 421
    記事 Megumi Kakechi · 1月 30, 2022 1m read

    これは、InterSystems FAQサイトの記事です。

    TRY-CATCHで行うことが可能です。
    以下のように行ってください。

     #dim ex As %Exception.AbstractException
     TRY {
        "<何かエラーを発生させる処理>"
      }
      CATCH ex {
         do ex.Log()
      }


    ^%ETNを使用する場合は、^%ETNを呼び出す際にBACKエントリ(BACK^%ETN)から呼び出してください。


    あわせて、以下の関連記事も是非ご覧ください。

    アプリケーションエラー(^ERRORS)をコマンドで取得する方法
    【FAQ】アプリケーションから明示的にエラー詳細情報をログ出力する方法を教えてください。

    0
    1 372
    記事 Toshihiko Minamoto · 1月 27, 2022 11m read

    はじめに

    バージョン2019.2より、InterSystems IRISは、高性能データアクセス手法としてPython用のネイティブAPIを提供してきました。 ネイティブAPIを使用すると、ネイティブのIRISデータ構造と直接対話することができます。

    0
    0 526
    記事 Toshihiko Minamoto · 1月 25, 2022 9m read

    キーワード: PyODBC、unixODBC、IRIS、IntegratedML、Jupyterノートブック、Python 3

    目的

    数か月前、私は「IRISデータベースへのPython JDBC接続」という簡易メモを書きました。以来、PCの奥深くに埋められたスクラッチパッドよりも、その記事を頻繁に参照しています。 そこで今回は、もう一つの簡易メモで「IRISデータベースへのPython ODBC接続」を作成する方法を説明します。

    ODBCとPyODCBをWindowsクライアントでセットアップするのは非常に簡単なようですが、Linux/Unix系サーバーでunixODBCとPyODBCクライアントをセットアップする際には毎回、どこかで躓いてしまいます。

    バニラLinuxクライアントで、IRISをインストールせずに、リモートIRISサーバーに対してPyODBC/unixODBCの配管をうまく行うための単純で一貫したアプローチがあるのでしょうか。

    範囲

    最近、Linux Docker環境のJupyterノートブック内でゼロからPyODBCデモを機能させるようにすることに少しばかり奮闘したことがありました。 そこで、少し冗長的ではありますが、後で簡単に参照できるように、これをメモに残しておくことにしました。  

    範囲内 

    このメモでは、以下のコンポーネントに触れます。

    0
    0 1216
    お知らせ Mihoko Iijima · 1月 17, 2022

    開発者の皆さん、こんにちは!

    InterSystems データセットコンテスト の投票結果が発表されました!この記事ではコンテスト受賞者を発表します!

    受賞された開発者の皆さん、👏おめでとうございます!🎊

    0
    0 120
    記事 Megumi Kakechi · 1月 12, 2022 5m read

    これは、InterSystems FAQサイトの記事です。
    ミラージャーナルファイルの削除(パージ)のタイミングは以下のようになります。

    ・プライマリ・フェイルオーバー・メンバ

     以下の期限のうち長い方に該当するもの
     -ローカルジャーナルファイルの削除条件が満たされたとき ("ジャーナル設定の構成" を参照)  
     -バックアップメンバとすべての非同期メンバに受信されたとき
      ただし、非同期メンバが14日間(既定値)を経過してもジャーナルファイルを受信しない場合は、そのジャーナルファイルは削除対象になります。
      「既定の14日間」は、以下のコマンドで設定が可能になります。
      この保持期間を過ぎると、ジャーナルが削除されてしまいその非同期メンバでは同期が取れなくなるのでご注意ください。

    %SYS>write ##class(SYS.Mirror).JrnPurgeDefaultWait(10)       // 引数で保持期間を渡す


    ・バックアップ・フェイルオーバー・メンバ およびすべての災害復旧 (DR) 非同期メンバ

    0
    0 314
    お知らせ Mihoko Iijima · 1月 10, 2022

    開発者の皆さん、こんにちは!

    今週から データセットコンテスト の投票が始まります!

    InterSystems IRIS を使い開発されたベストソリューションにぜひ、投票をお願いします!

    🔥 投票はこちらから! 🔥

    投票方法については、以下ご参照ください。

    0
    0 97
    記事 Toshihiko Minamoto · 1月 6, 2022 9m read

    キーワード: Python、JDBC、SQL、IRIS、Jupyterノートブック、Pandas、Numpy、および機械学習 

    1. 目的

    これは、デモの目的で、Jupyterノートブック内でPython 3によってIRIS JDBCドライバーを呼び出し、SQL構文でIRISデータベースインスタンスにデータを読み書きする、5分程度の簡単なメモです。 

    昨年、私はCacheデータベースへのPythonバインディング(セクション4.7)について簡単に触れました。 そこで、Pythonを使ってIRISデータベースに接続し、そのデータをPandasデータフレームとNumPy配列に読み込んで通常の分析を行ってから、事前処理済みまたは正規化されたデータをML/DLパイプラインに通すためにIRISに書き込む作業においてのオプションと議論について要約しましょう。

    すぐに思い浮かぶ簡単なオプションがいくつかあります。

    0
    0 1044
    記事 Hiroshi Sato · 12月 28, 2021 2m read

    これは InterSystems FAQ サイトの記事です。
     

    コンパイル時のフラグや修飾子の記号と意味については、以下ドキュメントをご参照ください。


    コンパイルフラグについて【IRIS】

    コンパイルフラグについて

    なお、開発環境のスタジオやVisual Studio Codeでは、開発環境の設定画面でフラグを変更できます。

    • スタジオは、[ツール] > [オプション] > [コンパイラ] > [フラグと最適化]

       

       

    • VSCodeは、[View] > [Command Palette...] 

     


    ターミナルでコンパイルを実行するときは $system.OBJ.CompileAll() などのシステムユーティリティが利用できます。
    コンパイルフラグを引数に指定しない場合、デフォルトのコンパイルフラグが利用されます。デフォルトのフラグは $system.OBJ.ShowFlags() で確認できます。

    0
    0 878
    記事 Hiroshi Sato · 12月 28, 2021 1m read

    これは、InterSystems FAQサイトの記事です。
     

    データ項目の値が”#Deleted"と表示される場合、MS Accessの設定でこの問題を回避することができます(MS Access2016以降)。

    MS Accessのオプションより、「大きい数値(BigInt)データ型をサポート」にチェックを入れます。

       

    設定後、リンクテーブルを一度閉じて、リンクの更新を行います。

    0
    0 9702
    記事 Tomoko Furuzono · 12月 26, 2021 1m read

    これは、InterSystems FAQサイトの記事です。

    MM/DD/YY-hh:mm:ss:fff ( ) 0 [Utility.Event] Purging old application errors

     
    こちらのメッセージは、エラーではなく、アプリケーションのエラーログを記録した古い ^ERRORSグローバルのパージ処理が実行された際に出力されるメッセージになります。ログを削除した旨のみを伝えるメッセージであり、出力されていても特に問題はありません。
    また、このログは、^ERRORSグローバルのパージ処理がタスク実行される毎日01:00 に出力されます。
     

    実際にアプリケーションエラーがある場合は、管理ポータルの [システムオペレーション] > [システムログ] > [アプリケーションエラーログ] にて、詳細を確認できます。
    ※このエラーログの内容は、各ネームスペースの ^ERRORS グローバルに格納されているものです。

       

    0
    0 283
    記事 Tomoko Furuzono · 12月 26, 2021 1m read

    これは、InterSystems FAQサイトの記事です。
    $ZTIMESTAMPはUTC形式で日付時刻を返すため、ローカルのタイムゾーンに変更するためには以下システムオブジェクトを利用します。 

     $SYSTEM.Util.UTCtoLocalWithZTIMEZONE($ZTIMESTAMP)


    上記出力結果は ddddd,sssss.fff の形式で出力されます。

        ddddd:$HOROLOGの日付と同じ形式
     sssss:現在の日付の午前 0 時からの経過秒数を示す整数
     fff :秒の小数部を示す可変桁数

    ※ $HOROLOGに似ていますが、$HOROLOGには秒の小数部分は含まれません。 

    SAMPLES>write $SYSTEM.Util.UTCtoLocalWithZTIMEZONE($ZTIMESTAMP)," - ", $horolog,!
    63895,64252.66 - 63895,64252
    SAMPLES>write $ZDATETIME($SYSTEM.Util.UTCtoLocalWithZTIMEZONE($ZTIMESTAMP),8)
    20151209 17:45:56
    SAMPLES>write $ZDATETIME($ZTIMESTAMP,8)
    20151209 08:46:05
    SAMPLES>
    0
    0 322