Menyesuaikan output

Pengantar Oracle SQL

Hadrien Lacroix

Content Developer

Fungsi

Fungsi dapat digunakan untuk:

  • perhitungan
  • pemformatan
  • manipulasi
  • konversi tipe data
Pengantar Oracle SQL

Fungsi dan tipe data

Data numerik Data karakter Data tanggal
AVG x
SUM x
MIN x x x
COUNT x x x

Tipe data menentukan jenis data yang dapat dimuat kolom.

Pengantar Oracle SQL

Jenis fungsi

  • Fungsi karakter
    • Input: nilai karakter
    • Output: nilai karakter, numerik, tanggal
  • Fungsi numerik
    • Input: nilai numerik
    • Output: nilai numerik
  • Fungsi tanggal
  • Fungsi umum
  • Fungsi konversi
Pengantar Oracle SQL

Manipulasi huruf: huruf besar

UPPER(column): mengubah semua karakter alfabet menjadi huruf besar

SELECT UPPER(State) AS State, UPPER(PostalCode) AS PostalCode
FROM Customer
| State | PostalCode |
|-------|------------|
| CA    | 95014      |
| DF    | 71020-677  |
| AB    | T6G 2C7    |
| BC    | V6C 1G8    |
| QC    | H2G 1A7    |
| ...   |            |
Pengantar Oracle SQL

Manipulasi huruf: huruf kecil

LOWER(column): mengubah semua karakter alfabet menjadi huruf kecil

SELECT LOWER(Email) AS LowercaseEmail
FROM Customer
| LowercaseEmail           |
|--------------------------|
| [email protected]     |
| [email protected]    |
| [email protected]      |
| [email protected]    |
| ...                      |
Pengantar Oracle SQL

Mengambil substring

SUBSTR(column, m, n): mengembalikan bagian string dari posisi m, sepanjang n karakter

SELECT Phone
FROM Customer
| Phone             |
|-------------------|
| +56 02 635 4444   |
| +91 0124 39883988 |
| +44 0131 315 3300 |

Tujuan: Dapatkan kode negara dari nomor telepon tanpa +

Pengantar Oracle SQL

Mengambil substring

Tujuan: dapatkan kode negara dari nomor telepon tanpa +

SELECT Phone, SUBSTR(Phone, 2, 2) AS cc
FROM Customer
| Phone             | cc |
|-------------------|----|
| +56 (0)2 635 4444 | 56 |
| +91 0124 39883988 | 91 |
| +44 0131 315 3300 | 44 |
| +39 06 39733434   | 39 |
| +48 22 828 37 39  | 48 |
| ...               |    |
Pengantar Oracle SQL

Fungsi bertingkat

Tujuan: Buat username pelanggan dari 5 huruf pertama nama belakang dan id mereka

SELECT LastName, CustomerId, CONCAT(SUBSTR(LastName,1,5), CustomerId) AS UserName
FROM customer
| LastName | CustomerId | UserName |
|----------|------------|----------|
| Almeida  | 12         | Almei12  |
| Barnett  | 28         | Barne28  |
| Bernard  | 39         | Berna39  |
| Brooks   | 18         | Brook18  |
| Brown    | 29         | Chase21  |
| ...      |            |          |
Pengantar Oracle SQL

Fungsi karakter lain yang berguna

LENGTH(val): mengembalikan panjang string

SELECT LENGTH('cat')
3

REPLACE(val, m, n): ganti m dengan n dalam val

SELECT REPLACE('kayak', 'k', 'y')
yayay
Pengantar Oracle SQL

Pembulatan

ROUND(column, m): membulatkan column ke m desimal

SELECT Total, ROUND(Total, 1) AS Round1, ROUND(Total, 0) AS Whole 
FROM Invoice
| Total     | Round1 | Whole |
|-----------|--------|-------|
| 11.94     | 11.9   | 12    |
| 14.91     | 14.9   | 15    |
| 0.99      | 1.0    | 1     |
| 5.94      | 5.9    | 6     |
| 7.96      | 8.0    | 8     |
| ...       |        |       |
Pengantar Oracle SQL

Pemotongan (truncating)

TRUNC(column, m): memotong column ke m desimal

SELECT DISTINCT Total, ROUND(Total, 1) AS Dec1, TRUNC(Total, 1) AS Trun1 
FROM Invoice
| Total | Dec1 | Trun1 |
|-------|------|-------|
| 15.86 | 15.9 | 15.8  |
| 13.86 | 13.9 | 13.8  |
| 8.94  | 8.9  | 8.9   |
| 1.99  | 2.0  | 1.9   |
| 7.96  | 8.0  | 7.9   |
Pengantar Oracle SQL

Modulo

MOD(column1, column2): mengembalikan sisa pembagian

SELECT MOD(14, 4)
2
Pengantar Oracle SQL

Modulo

MOD(column1, column2): mengembalikan sisa pembagian

SELECT MOD(14, 2)
0
SELECT MOD(15, 2)
1
Pengantar Oracle SQL

Modulo

Apakah jumlah karyawan genap?

SELECT MOD(COUNT(Employee),1) 
FROM Employee
0

Ya.

Pengantar Oracle SQL

Ayo berlatih!

Pengantar Oracle SQL

Preparing Video For Download...