Excel DAX - Kecerdasan Waktu

DAX memiliki fitur penting dan kuat, yang disebut sebagai Time Intelligence. Kecerdasan waktu memungkinkan Anda untuk menulis rumus DAX yang merujuk ke periode waktu untuk digunakan di PivotTable.

DAX memiliki 35 fungsi kecerdasan waktu khusus untuk menggabungkan dan membandingkan data dari waktu ke waktu. Namun, fungsi DAX ini memiliki beberapa batasan pada data yang perlu Anda pahami dan bekerja dengan hati-hati untuk menghindari kesalahan.

Mengapa Kecerdasan Waktu Membuat DAX Kuat?

Fungsi kecerdasan waktu bekerja dengan data yang terus berubah, bergantung pada konteks yang Anda pilih dalam visualisasi PivotTable dan Power View. Seperti yang Anda ketahui, sebagian besar analisis data melibatkan peringkasan data selama periode waktu tertentu, membandingkan nilai data dalam periode waktu tersebut, memahami tren, dan membuat keputusan berdasarkan proyeksi masa depan.

Misalnya, Anda mungkin ingin menjumlahkan jumlah penjualan untuk produk bulan lalu dan membandingkan totalnya dengan bulan-bulan lain dalam tahun fiskal. Ini berarti, Anda harus menggunakan tanggal sebagai cara untuk mengelompokkan dan mengumpulkan transaksi penjualan untuk periode waktu tertentu.

Di sinilah Anda dapat mengamati kekuatan DAX. Anda bisa menggunakan fungsi kecerdasan waktu DAX untuk menentukan bidang terhitung yang membantu Anda menganalisis data dari waktu ke waktu, tanpa harus mengubah pilihan tanggal di tabel pivot. Ini membuat pekerjaan Anda lebih mudah. Selain itu, Anda dapat membuat PivotTable yang tidak mungkin dilakukan dengan cara lain.

Persyaratan untuk DAX Time Intelligence Functions

Fungsi kecerdasan waktu DAX memiliki persyaratan tertentu. Jika persyaratan ini tidak terpenuhi, Anda mungkin mendapatkan kesalahan atau mungkin tidak berfungsi dengan benar. Oleh karena itu, Anda dapat merujuk ke persyaratan ini sebagai aturan atau batasan juga. Berikut adalah beberapa persyaratan / aturan / batasan fungsi kecerdasan waktu DAX -

  • Anda harus memiliki tabel tanggal di Model Data Anda.

  • Tabel tanggal harus menyertakan kolom yang dianggap sebagai kolom tanggal oleh DAX. Anda dapat memberi nama kolom sesuai keinginan Anda, tetapi kolom tersebut harus memenuhi ketentuan berikut: o Kolom tanggal harus berisi sekumpulan tanggal yang berdekatan yang mencakup setiap hari dalam periode waktu Anda menganalisis data.

    • Setiap tanggal harus ada satu kali dan hanya sekali di kolom tanggal.

    • Anda tidak dapat melewatkan tanggal mana pun (Misalnya, Anda tidak dapat melewatkan tanggal akhir pekan).

  • Fungsi kecerdasan waktu DAX hanya berfungsi pada kalender standar dan mengasumsikan awal tahun sebagai 1 Januari dan akhir tahun sebagai 31 Desember, dengan bulan dalam tahun dan hari di setiap bulan sebagai tahun kalender.

Namun, Anda dapat menyesuaikan kalender standar untuk tahun keuangan yang berbeda. Merupakan praktik yang baik untuk memverifikasi persyaratan di atas sebelum fungsi intelijen waktu digunakan.

Untuk detail selengkapnya tentang tabel tanggal dan penggunaannya dalam rumus DAX, lihat tutorial = Pemodelan Data dengan DAX di pustaka tutorial ini.

DAX Time Intelligence Functions - Kategori

Fungsi DAX Time Intelligence dapat dikategorikan sebagai berikut -

  • Fungsi DAX yang mengembalikan satu tanggal.
  • Fungsi DAX yang mengembalikan tabel tanggal.
  • Fungsi DAX yang mengevaluasi ekspresi selama jangka waktu tertentu.

Fungsi DAX Yang Mengembalikan Tanggal Tunggal

Fungsi DAX dalam kategori ini mengembalikan satu tanggal.

Ada 10 fungsi DAX dalam kategori ini -

Sr.No. Fungsi DAX & Nilai Pengembalian
1

FIRSTDATE (Date_Column)

Mengembalikan tanggal pertama di Date_Column dalam konteks saat ini.

2

LASTDATE (Date_Column)

Mengembalikan tanggal terakhir di Date_Column dalam konteks saat ini.

3

FIRSTNONBLANK (Date_Column, Expression)

Mengembalikan tanggal pertama ketika ekspresi memiliki nilai yang tidak kosong.

4

LASTNONBLANK (Date_Column, Expression)

Mengembalikan tanggal terakhir di mana ekspresi memiliki nilai yang tidak kosong.

5

STARTOFMONTH (Date_Column)

Mengembalikan tanggal pertama dalam sebulan dalam konteks saat ini.

6

ENDOFMONTH (Date_Column)

Mengembalikan tanggal terakhir dalam sebulan dalam konteks saat ini.

7

STARTOFQUARTER (Date_Column)

Menampilkan tanggal pertama dari satu kuartal dalam konteks saat ini.

8

ENDOFQUARTER (Date_Column)

Mengembalikan tanggal terakhir dari satu kuartal dalam konteks saat ini.

9

STARTOFYEAR (Date_Column, [YE_Date])

Mengembalikan tanggal pertama dalam setahun dalam konteks saat ini.

10

ENDOFYEAR (Date_Column, [YE_Date])

Mengembalikan tanggal terakhir dalam setahun dalam konteks saat ini.

Fungsi DAX yang Mengembalikan Tabel Tanggal

Fungsi DAX dalam kategori ini mengembalikan tabel tanggal. Fungsi ini akan banyak digunakan sebagai argumen SetFilter untuk fungsi DAX - HITUNG.

Ada 16 fungsi DAX dalam kategori ini. Delapan (8) dari fungsi DAX ini adalah fungsi "sebelumnya" dan "berikutnya".

  • Fungsi "sebelumnya" dan "berikutnya" dimulai dengan kolom tanggal dalam konteks saat ini dan menghitung hari, bulan, kuartal, atau tahun sebelumnya atau berikutnya.

  • Fungsi "sebelumnya" bekerja mundur dari tanggal pertama dalam konteks saat ini dan fungsi "berikutnya" bergerak maju dari tanggal terakhir dalam konteks saat ini.

  • Fungsi "sebelumnya" dan "berikutnya" mengembalikan tanggal yang dihasilkan dalam bentuk tabel kolom tunggal.

Sr.No. Fungsi DAX & Nilai Pengembalian
1

PREVIOUSDAY (Date_Column)

Mengembalikan tabel yang berisi kolom semua tanggal yang mewakili hari sebelum tanggal pertama di Date_Column dalam konteks saat ini.

2

NEXTDAY (Date_Column)

Mengembalikan tabel yang berisi kolom semua tanggal dari hari berikutnya, berdasarkan tanggal pertama yang ditentukan di Date_Column dalam konteks saat ini.

3

PREVIOUSMONTH (Date_Column)

Mengembalikan tabel yang berisi kolom semua tanggal dari bulan sebelumnya, berdasarkan tanggal pertama di Date_Column dalam konteks saat ini.

4

NEXTMONTH (Date_Column)

Mengembalikan tabel yang berisi kolom semua tanggal dari bulan berikutnya, berdasarkan tanggal pertama di Date_Column dalam konteks saat ini.

5

PREVIOUSQUARTER (Date_Column)

Mengembalikan tabel yang berisi kolom semua tanggal dari kuartal sebelumnya, berdasarkan tanggal pertama di Date_Column dalam konteks saat ini.

6

NEXTQUARTER (Date_Column)

Mengembalikan tabel yang berisi kolom semua tanggal di kuartal berikutnya, berdasarkan tanggal pertama yang ditentukan di Date_Column dalam konteks saat ini.

7

PREVIOUSYEAR (Date_Column, [YE_Date])

Mengembalikan tabel yang berisi kolom semua tanggal dari tahun sebelumnya, diberi tanggal terakhir di Date_Column dalam konteks saat ini.

8

NEXTYEAR (Date_Column, [YE_Date])

Mengembalikan tabel yang berisi kolom dari semua tanggal di tahun depan, berdasarkan tanggal pertama di Date_Column dalam konteks saat ini.

Empat (4) fungsi DAX menghitung sekumpulan tanggal dalam satu periode. Fungsi-fungsi ini melakukan kalkulasi menggunakan tanggal terakhir dalam konteks saat ini.

Sr.No. Fungsi DAX & Nilai Pengembalian
1

DATESMTD (Date_Column)

Mengembalikan tabel yang berisi kolom tanggal untuk bulan ini, dalam konteks saat ini.

2

DATESQTD (Date_Column)

Mengembalikan tabel yang berisi kolom tanggal untuk kuartal sampai saat ini, dalam konteks saat ini.

3

DATESYTD (Date_Column, [YE_Date])

Mengembalikan tabel yang berisi kolom tanggal untuk tahun ini, dalam konteks saat ini.

4

SAMEPERIODLASTYEAR (Date_Column)

Mengembalikan tabel yang berisi kolom tanggal yang bergeser satu tahun ke belakang dari tanggal di Date_Column yang ditentukan, dalam konteks saat ini.

Note- SAMEPERIODLASTYEAR mengharuskan konteks saat ini berisi sekumpulan tanggal yang berdekatan.

Jika konteks saat ini bukan kumpulan tanggal yang berdekatan, maka SAMEPERIODLASTYEAR akan mengembalikan kesalahan.

  • Empat (4) fungsi DAX digunakan untuk beralih dari kumpulan tanggal yang ada dalam konteks saat ini ke kumpulan tanggal baru.

    Fungsi DAX ini lebih andal dari yang sebelumnya.

    • Fungsi DAX - DATEADD, DATESINPERIOD dan PARALLELPERIOD menggeser beberapa interval waktu dari konteks saat ini. Intervalnya bisa hari, bulan, kuartal atau tahun, diwakili oleh kata kunci - HARI, BULAN, KUARTAL dan TAHUN.

      Sebagai contoh:

  • Geser mundur 2 hari.

  • Maju selama 5 bulan.

  • Maju satu bulan dari hari ini.

  • Kembali ke kuartal yang sama tahun lalu.

      Jika argumen fungsi - jumlah interval (nilai integer) positif, shift maju dan jika negatif, shift mundur.

    • Fungsi DAX - DATESBETWEEN menghitung kumpulan tanggal antara tanggal mulai yang ditentukan dan tanggal akhir.

Sr.No. Fungsi DAX & Nilai Pengembalian
1

DATEADD (Date_Column, Number_of_Intervals, Interval)

Mengembalikan tabel yang berisi kolom tanggal, digeser maju atau mundur dalam waktu dengan jumlah interval yang ditentukan dari tanggal dalam konteks saat ini.

2

DATESINPERIOD (Date_Column, Start_Date, Number_of_Intervals, Interval)

Mengembalikan tabel yang berisi kolom tanggal yang dimulai dengan start_date dan berlanjut untuk number_of_intervals tertentu.

3

PARALLELPERIOD (Date_Column, Number_of_Intervals, Interval)

Mengembalikan tabel yang berisi kolom tanggal yang mewakili periode sejajar dengan tanggal di Date_Column yang ditentukan dalam konteks saat ini, dengan tanggal bergeser sejumlah interval baik maju atau mundur dalam waktu.

4

DATESBETWEEN (Date_Column, Start_Date, End_Date)

Menampilkan tabel yang berisi kolom tanggal yang dimulai dengan start_date dan berlanjut sampai tanggal_akhir.

Fungsi DAX yang Mengevaluasi Ekspresi Selama Jangka Waktu

Fungsi DAX dalam kategori ini mengevaluasi ekspresi selama jangka waktu tertentu.

Ada sembilan (9) fungsi DAX dalam kategori ini -

  • Tiga (3) fungsi DAX dalam kategori ini dapat digunakan untuk mengevaluasi ekspresi yang diberikan selama periode waktu tertentu.

Sr.No. Fungsi DAX & Nilai Pengembalian
1

TOTALMTD (Expression, Date_Column, [SetFilter])

Mengevaluasi nilai ekspresi untuk tanggal di bulan sampai saat ini, dalam konteks saat ini.

2

TOTALQTD (Expression, Date_Column, [SetFilter])

Mengevaluasi nilai ekspresi untuk tanggal dalam kuartal hingga saat ini, dalam konteks saat ini.

3

TOTALYTD (Expression, Date_Column, [SetFilter], [YE_Date])

Mengevaluasi nilai ekspresi untuk tanggal di tahun ini, dalam konteks saat ini

  • Enam (6) fungsi DAX dalam kategori ini dapat digunakan untuk menghitung saldo awal dan akhir.

    • Saldo awal untuk setiap periode sama dengan saldo akhir periode sebelumnya.

    • Saldo penutupan mencakup semua data hingga akhir periode, sedangkan saldo pembukaan tidak termasuk data apa pun dari dalam periode saat ini.

    • Fungsi DAX ini selalu mengembalikan nilai ekspresi yang dievaluasi untuk titik waktu tertentu.

  • Titik waktu yang kita pedulikan selalu kemungkinan nilai tanggal terakhir dalam periode kalender.

  • Saldo pembukaan didasarkan pada tanggal terakhir periode sebelumnya, sedangkan saldo penutupan didasarkan pada tanggal terakhir pada periode berjalan.

  • Periode saat ini selalu ditentukan oleh tanggal terakhir dalam konteks tanggal saat ini.

Sr.No. Fungsi DAX & Nilai Pengembalian
1

OPENINGBALANCEMONTH (Expression, Date_Column, [SetFilter])

Mengevaluasi ekspresi pada tanggal pertama setiap bulan dalam konteks saat ini.

2

CLOSINGBALANCEMONTH (Expression, Date_Column, [SetFilter])

Mengevaluasi ekspresi pada tanggal terakhir bulan itu dalam konteks saat ini.

3

OPENINGBALANCEQUARTER (Expression, Date_Column, [SetFilter])

Mengevaluasi ekspresi pada tanggal pertama kuartal, dalam konteks saat ini.

4

CLOSINGBALANCEQUARTER (Expression, Date_Column, [SetFilter])

Mengevaluasi ekspresi pada tanggal terakhir kuartal dalam konteks saat ini.

5

OPENINGBALANCEYEAR (Expression, Date_Column, [SetFilter], [YE_Date])

Mengevaluasi ekspresi pada tanggal pertama tahun ini dalam konteks saat ini.

6

CLOSINGBALANCEYEAR (Expression, Date_Column, [SetFilter], [YE_Date])

Mengevaluasi ekspresi pada tanggal terakhir tahun ini dalam konteks saat ini.