MSAccess-組み込み関数
この章では、組み込み関数を使用します。Accessには、100近くの組み込み関数があり、それらすべてを網羅することはほとんど不可能です。この章では、基本的な構造、構文について説明し、より一般的な関数のいくつかと落とし穴を使用して、他の関数のいくつかを自分で探索できるようにします。
関数
関数は、タスクまたは計算を実行し、結果を返すVBAプロシージャです。関数は通常、クエリで使用できますが、関数を使用できる場所は他にもあります。
テーブルプロパティで関数を使用できます。たとえば、日付/時刻フィールドにデフォルト値を指定する場合は、日付またはを使用できます。 Now システムから現在の日付/時刻情報を呼び出し、その値を自動的に入力する機能。
計算フィールドを作成するときに式で関数を使用したり、フォームまたはレポートコントロール内で関数を使用したりすることもできます。マクロ引数でも関数を使用できます。
関数は非常に単純で、他の情報を呼び出す必要がない場合もあれば、テーブルまたはクエリから1つのフィールドを参照する場合もあります。
一方、複数の引数、フィールド参照、さらには別の関数内にネストされた他の関数など、非常に複雑になる可能性もあります。
ここで、組み込み関数の使用例をいくつか見てみましょう。
日付と時刻の関数
日付と時刻の関数を理解しましょう-
Date()関数は、現在のシステム日付を返すように設計されています。この関数は、関数の引数や追加情報を必要としません。あなたがしなければならないのは、関数の名前とそれらの開き括弧と閉じ括弧を書くことだけです。
2つの非常によく似た組み込み関数Time()とNow()があります。
Time()関数は現在のシステム時刻のみを返し、Now()関数は現在のシステム日付と時刻の両方を返します。
追跡、保存、またはクエリするデータに応じて、そのタスクを支援する3つの組み込みの使いやすい関数があります。
データベースを開き、クエリデザインを使用して新しいクエリを作成し、tblProjectsとtblTasksを追加しましょう。
tblProjectsとTaskTitleからProjectNameを追加し、tblTasksからStartDateとDueDateを追加して、クエリを実行します。
これで、すべてのプロジェクトのさまざまなタスクをすべて表示できます。今日の日付で進行中のプロジェクトタスクを表示する場合は、を使用して基準を指定する必要があります。Date() 今日の日付以降に開始するプロジェクトを確認する機能。
ここで、StartDateの下に基準を指定しましょう。
基準は演算子で始まります greater than symbol、続いて equal to symbol その後 Date Function。
このクエリを実行すると、次のスクリーンショットのように、すべてのタスクが今日または将来のいずれかに発生します。
これは、Date()関数をクエリ条件として使用する方法の例です。
ここで、このクエリは、今週から取得する日付に関して、より柔軟である必要があるとしましょう。
今週開始されたいくつかの異なるタスクがありますが、基準のため、この現在のリストには表示されていません。今日と同じかそれ以上の開始日を見ています。
今週開始されたタスク、まだ完了していないタスク、または今日完了する予定のタスクを表示する場合は、デザインビューに戻ります。
ここでは、これらの基準にいくつかの追加情報を追加します。実際、今日の日付から7日を引いた値以上にする必要があります。
マイナス7を入力してクエリを実行すると、今週開始されたタスクも表示されます。
DateDiff()関数
DateDiff()関数は、もう1つの非常に人気のある日付/時刻関数です。DateDiff関数は、指定された2つの日付間の時間間隔の数を指定するバリアント(long)を返します。つまり、2つの日付の差を計算し、関数がその差を計算する間隔を選択できます。
ここで、著者の年齢を計算したいとしましょう。このために、最初に新しいクエリを作成して作成者テーブルを追加し、次にFirstName、LastName、およびBirthDayフィールドを追加する必要があります。
生年月日または誕生日と今日の日付との差を計算することで、人々の年齢を計算できます。
新しいフィールドでDateDiff関数を使用してみましょう。
それをAgeの後にコロンと呼び、DateDiff関数を記述します。
- DateDiff関数の最初の関数引数は間隔なので、「yyyy」と入力します。
- 次の関数の引数は、計算する最初の日付です。この場合は、Birthdayフィールドになります。
- 3番目の関数の引数は、今日の日付が何であれです。
ここでクエリを実行すると、各作成者の年齢を示す新しいフィールドが表示されます。
Format()関数
Format()関数は、フォーマット式に含まれる命令に従ってフォーマットされた式を含む文字列を返します。Format()関数で使用できるユーザー定義形式のリストは次のとおりです。
設定 | 説明 |
---|---|
yyyy | 年 |
q | 四半期 |
m | 月 |
y | 曜日 |
d | 日 |
w | 平日 |
ww | 週間 |
h | 時間 |
n | 分 |
s | 2番目 |
クエリに戻り、Format()関数を使用して同じフィールドにフィールドを追加しましょう。
フォーマット関数を入力します。最初の関数の引数は式になりますが、これはほとんど何でもかまいません。最初に誕生日フィールドを設定し、次はフォーマットを記述します。この場合、月、月、日、日が必要です。「mmdd」を引用符で囲んでから、クエリを実行します。
現在、誕生日フィールドから日付を取得しています。4は月、17は日です。
次のスクリーンショットのように、次のフィールドに「mmdd」の代わりに「mmm」と「mmmm」を追加しましょう。
クエリを実行すると、次のスクリーンショットのような結果が表示されます。
次のフィールドでは、その誕生日の月の名前から最初の3文字が返され、最後のフィールドでは完全な月の名前が返されます。
次のスクリーンショットに示すように、月とそれに続く誕生日の年を表示するには、「yyyy」を追加します。
クエリをもう一度実行してみましょう。
月、コンマ、年が表示されます。
IIf()関数
IIf()関数は「ImmediateIf」の省略形であり、この関数は式をtrueまたはfalseとして評価し、それぞれの値を返します。最大3つの関数引数があり、すべてが必須です。
- 最初の引数は、評価する式です。
- 次の引数は真の部分を表します。これは、最初の式が真の場合に返される値または式にすることができます。
- 最後の引数は、式がfalseの場合に返されるものです。
例
簡単な例を見てみましょう。クエリデザインを使用して新しいクエリを作成し、tblAuthorsテーブルを追加してから、次のフィールドを追加します。
これで、FirstName、MiddleInitial、LastNameの3つのフィールドと、3つのフィールドすべてをまとめるこの連結フィールドがあることがわかります。クエリを実行して、このクエリの結果を確認しましょう。
これで、クエリの結果を確認できますが、一部のレコードにミドルネームのイニシャルがないことにも気付くでしょう。たとえば、Joyce Dyerレコードにはミドルネームのイニシャルはありませんが、[FullName]フィールドには、実際にそこにある必要のない期間が表示されます。したがって、デザインビューに戻ります。ここでは、IIf関数を使用して別の方法で名前を連結します。
別のフィールドに名前を入力してFullName1と呼び、IIf関数を入力してみましょう。
ImmediateIf関数の最初の関数引数が式になります。式では、中央の初期フィールドが空白であるかnullであるかを確認します。
次の議論は本当の部分です。したがって、ミドルネームのイニシャルがnullの場合は、FirstNameとLastNameを表示する必要があります。
ここで、誤った部分について— MiddleInitialがnullでない場合は、FirstName、MiddleInitial、およびLastNameを表示する必要があります。
クエリを実行すると、次のスクリーンショットのような結果が表示されます。