Çıktıyı özelleştirme

Oracle SQL'ye Giriş

Hadrien Lacroix

Content Developer

Fonksiyonlar

Fonksiyonlar şunlar için kullanılır:

  • hesaplama
  • biçimlendirme
  • düzenleme
  • veri türleri arasında dönüştürme
Oracle SQL'ye Giriş

Fonksiyonlar ve veri türleri

Sayısal veri Karakter verisi Tarih verisi
AVG x
SUM x
MIN x x x
COUNT x x x

Veri türleri, bir sütunun hangi veriyi içerebileceğini tanımlar.

Oracle SQL'ye Giriş

Fonksiyon türleri

  • Karakter fonksiyonları
    • Girdi: karakter değerleri
    • Çıktı: karakter, sayısal, tarih değerleri
  • Sayı fonksiyonları
    • Girdi: sayısal değerler
    • Çıktı: sayısal değerler
  • Tarih fonksiyonları
  • Genel fonksiyonlar
  • Dönüşüm fonksiyonları
Oracle SQL'ye Giriş

Büyük/küçük harf: büyük harf

UPPER(column): tüm alfabetik karakterleri büyük harfe çevirir

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    |
| ...   |            |
Oracle SQL'ye Giriş

Büyük/küçük harf: küçük harf

LOWER(column): tüm alfabetik karakterleri küçük harfe çevirir

SELECT LOWER(Email) AS LowercaseEmail
FROM Customer
| LowercaseEmail           |
|--------------------------|
| [email protected]     |
| [email protected]    |
| [email protected]      |
| [email protected]    |
| ...                      |
Oracle SQL'ye Giriş

Alt dize alma

SUBSTR(column, m, n): bir dizgenin m. konumundan başlayarak n karakterini döndürür

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

Amaç: + olmadan bir telefon numarasının ülke kodunu alın

Oracle SQL'ye Giriş

Alt dize alma

Amaç: + olmadan bir telefon numarasının ülke kodunu alın

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 |
| ...               |    |
Oracle SQL'ye Giriş

İç içe fonksiyonlar

Amaç: Müşteriler için kullanıcı adlarını, soyadının ilk 5 harfi ile id'lerini birleştirerek üretin

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  |
| ...      |            |          |
Oracle SQL'ye Giriş

Diğer yararlı karakter fonksiyonları

LENGTH(val): bir dizgenin uzunluğunu döndürür

SELECT LENGTH('cat')
3

REPLACE(val, m, n): val içinde m'yi n ile değiştirir

SELECT REPLACE('kayak', 'k', 'y')
yayay
Oracle SQL'ye Giriş

Yuvarlama

ROUND(column, m): column değerini m ondalığa yuvarlar

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     |
| ...       |        |       |
Oracle SQL'ye Giriş

Kesme (truncation)

TRUNC(column, m): column değerini m ondalıkta keser

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   |
Oracle SQL'ye Giriş

Modül (modulo)

MOD(column1, column2): bölümden kalanı döndürür

SELECT MOD(14, 4)
2
Oracle SQL'ye Giriş

Modül (modulo)

MOD(column1, column2): bölümden kalanı döndürür

SELECT MOD(14, 2)
0
SELECT MOD(15, 2)
1
Oracle SQL'ye Giriş

Modül (modulo)

Çift sayıda çalışan var mı?

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

Evet.

Oracle SQL'ye Giriş

Haydi pratik yapalım!

Oracle SQL'ye Giriş

Preparing Video For Download...