findMatching2SFormWithinRange( )
検索キーとして指定された項目値と一致する、行IDで識別される2セクション・フォームの繰返しセクションのインスタンスを検索します。検索は、検索キーまたは日付範囲に基づいて行うことができます。
この関数について:
- ドロップダウン、ラジオ・ボタンまたはチェック・ボックス値を関数パラメータまたはターゲットとして使用することはできません。
- 最初の2つのパラメータは、常に日付範囲である必要があります。その後、追加の検索キーを指定できます。
- この関数は、日付が
null
であるエントリも考慮します。繰返しフォーム・インスタンスの開始日または終了日がnullの場合、日付範囲重複チェックを正常に実行するために日付が想定されます。- 開始日が
null
の場合、0001年1月1日とみなされます。 - 終了日が
null
の場合、3099年12月1日とみなされます。
- 開始日が
- 変数が日付の一部を保持するように設計されている場合は、そのパラメータの値を同じ日付形式で指定します。日付の一部を次の書式で使用できます。
- <dd- mmm- yyyy hh:mm>
- <dd- mmm- yyyy hh>
- <dd- mmm- yyyy>
- <mmm- yyyy>
- <yyyy>
ルールは、日付が重複する2セクション形式の繰返しセクション・インスタンスの索引を返します。
注意:
この関数は、日付が nullのエントリも考慮します。これは集計関数です。ターゲットが2セクション・フォームの繰返しセクションにある場合、ルールは各インスタンスに対して実行されます。
構文
findMatching2SFormWithinRange('startDateVariable',startDateValue, 'endDateVariable', endDateValue, 'variable1', value1, 'variable2', value2, ...)
パラメータ
ノート:
ルール式の他の場所でこの関数に渡された変数を再利用できますが、一重引用符を使用して変数をパラメータとして追加する必要があります。- startDateVariable
-
必須。日付アイテム。
- startDateValue
-
必須。文字列形式の日付値。
これらはハードコードする必要があり、ルール変数にはできません。- 日付は、文字列
'Date(dd-mmm-yyyy hh:mm:ss)'
内に指定する必要があります。 - 日付の一部を次の書式で使用できます。
- <dd- mmm- yyyy hh:mm>
- <dd- mmm- yyyy hh>
- <dd- mmm- yyyy>
- <mmm- yyyy>
- <yyyy>
- 時間は、文字列
'Time(hh:mm:ss)'
内に指定する必要があります。 - 時間の一部は、次の形式で使用できます。
- <h:mm>
- <hh>
- 日付は、文字列
- endDateVariable
-
必須。日付アイテム。
- DateValue
-
必須。文字列形式の日付値。
startDateValueパラメータと同じ要件を検討してください。
- 変数
-
オプション。検索するアイテム変数。
- 値
-
オプション。検索値。これらはハードコードする必要があり、ルール変数にはできません。
戻り値
一致するインスタンスが見つからない場合は - 1を返し、一致するインスタンスが少なくとも1つ見つかった場合は2セクション形式の繰り返しセクションのインスタンスのインデックス番号(>0)を返します。複数のインスタンスが見つかった場合は、最初の索引のみが返されます。
注意:
日付では、UNK
値は他の値と一致するとみなされます。たとえば、'Date(01-Feb-2022)'
と'Date(20-Feb-2022)'
は両方とも、UNK-Feb-2022
日付値を持つエントリの照合とみなされます。
例3-68 Date変数が指定された範囲内にあるインスタンスが存在し、一致する他の条件が存在する場合に問合せを発生させます
// Given 5 repeating form instances with items "onsetStart", "onsetEnd" and "itmSymptom"
//Raises query if symptom = "headache" AND onSet date is between Jan 1 2020 and March 1 2020
if (findMatching2SFormWithinRange('onsetStart', 'Date(01-JAN-2020)', 'onsetEnd', 'Date(01-MAR-2020)', 'itmSymptom', "headache") > 0) {
return false;
} else {
return true;
}
// Fires query if any of the 5 instances contain onset dates between Jan 1 2020 - March 1 2020 AND itmSymptom = "headache"
//if rule variable (datetimeVar) is datetime componentif (findMatching2SFormWithinRange(2, 'onsetStart', 'Date(01-JAN-2020)', 'onsetEnd', 'Date(01-MAR-2020)', 'datetimeVar', 'Date(10-Jun-2010 11:12:15)') > 0) {
return false;
} else {
return true;
}
//if rule variable (timeVar) is time componentif (findMatching2SFormWithinRange(2, 'onsetStart', 'Date(01-JAN-2020)', 'onsetEnd', 'Date(01-MAR-2020)', 'timeVar', 'Time(11:12:15)') > 0) {
return false;
} else {
return true;
}
親トピック: 2セクション・フォーム関数