PostgreSQL'yi Genişletme

PostgreSQL'de Veriyi İşlemek için Fonksiyonlar

Brian Piccolo

Sr. Director, Digital Strategy

Kullanıcı tanımlı veri türleri

Numaralandırılmış veri türleri

CREATE TYPE dayofweek AS ENUM (
      'Monday', 
      'Tuesday',
      'Wednesday', 
      'Thursday', 
      'Friday', 
      'Saturday', 
      'Sunday'
);
PostgreSQL'de Veriyi İşlemek için Fonksiyonlar

Kullanıcı tanımlı veri türleri hakkında bilgi alma

SELECT typname, typcategory
FROM pg_type
WHERE typname='dayofweek';
+-----------+-------------+
| typname   | typcategory |
|-----------|-------------|
| dayofweek | E           |
+-----------+-------------+
PostgreSQL'de Veriyi İşlemek için Fonksiyonlar

Kullanıcı tanımlı veri türleri hakkında bilgi alma

SELECT column_name, data_type, udt_name
FROM INFORMATION_SCHEMA.COLUMNS 
WHERE table_name ='film';
+-----------------------------------------------+
| column_name | data_type         | udt_name    |
|-------------|-------------------|-------------|
| title       | character varying | varchar     |
| rating      | USER-DEFINED      | mpaa_rating |
+-----------------------------------------------+
PostgreSQL'de Veriyi İşlemek için Fonksiyonlar

Kullanıcı tanımlı fonksiyonlar

CREATE FUNCTION squared(i integer) RETURNS integer AS $$
    BEGIN
        RETURN i * i;
    END;
$$ LANGUAGE plpgsql;
SELECT squared(10);
+---------+
| squared |
|---------|
| 100     |
+---------+
PostgreSQL'de Veriyi İşlemek için Fonksiyonlar

Sakila veritabanında kullanıcı tanımlı fonksiyonlar

  • get_customer_balance(customer_id, effective_data): Belirli bir müşterinin güncel bakiye borcunu hesaplar.

  • inventory_held_by_customer(inventory_id): Bir envanter öğesini şu anda kiralayan customer_id'yi döndürür; müsaitse null döner.

  • inventory_in_stock(inventory_id): Envanter öğesinin stokta olup olmadığını belirten boolean döndürür.
PostgreSQL'de Veriyi İşlemek için Fonksiyonlar

Haydi pratik yapalım!

PostgreSQL'de Veriyi İşlemek için Fonksiyonlar

Preparing Video For Download...