Doctrine postgresql fonksiyonlari
Symfony ile uygulama geliştirirken tüm veritabanı işlemleri Doctrine üzerinden gerçekleştiriliyor. Doctrine ise tüm veritabanlarına ortada durabilmek adına maksimum ortak paydaya ulaşarak buna uygun programlanıyor.
Yani bir özellik geliştirileceği zaman, en optimum şekilde, tüm veritabanlarına uyacak kadarını geliştiriyorlar. Bu sebeple PostgreSQL’in pek çok güzel özelliği içerisinde gelmiyor.
Tabi ki native sql
yazarak Doctrine içerisinden direkt saf PostgreSQL sorgusu çalıştırabiliyorsunuz. Fakat benim bahsetmek istediğim Doctrine’in diğer bir güzel özelliği kullanıcı tanımlı DQL fonksiyonları
kullanabiliyor olmak.
Çok detaya inmeden bahsetmek gerekirse; Doctrine SQL sorgularını yazılımcıdan DQL formatında talep edip, kendisi veritabanına uygun hale getirip SQL üretiyor. DQL formatında ise yukarıda bahsettiğim sebepten ötürü sadece belirli veritabanı özelliklerini destekleyebiliyor. Fakat DQL formatı genişletilebilir bir format olduğu için biz kendi DQL özelliklerimizi yazıp, Doctrine’e kazandırabiliyoruz.
PostgreSQL fonksiyonlarını kullanabilmek için de bu özellikten yararlanacağız. Doctrine kendi* sitesinde çok güzel şekilde nasıl kendi DQL fonksiyonları yazabileceğinizi anlatmış.
Peki ben niye konuşuyorum?
Tabi ki Martin Georgiev‘in zaten yazmış olduğu, PostgreSQL fonksiyonlarının DQL genişletmelerini içeren paketten bahsetmek için.
Composer ile paketi yükleyebiliyorsunuz.
composer require martin-georgiev/postgresql-for-doctrine
Sonrası ise kullanacağınız fonksiyonları, framework’ünüze özel olarak tanımlamak kalıyor. Bu bir Doctrine paketi olduğu için Symfony bağımlı değil, diğer frameworklerle veya frameworksüz de kullanabilirsiniz.
Symfony 5 için aşağıdaki gibi tanımlayabiliyorsunuz:
doctrine:
dbal:
types:
text[]: MartinGeorgiev\Doctrine\DBAL\Types\TextArray
mapping_types:
text[]: text[]
_text: text[]
orm:
dql:
string_functions:
ANY_OF: MartinGeorgiev\Doctrine\ORM\Query\AST\Functions\Any
Sadece text[]
türünü ve ANY
fonksiyonunu yükledim bu örnekte. Tüm fonksiyon ve türler için postgresql-for-doctrine dökümanına göz atabilirsiniz.
Ayarlarınızı yaptıktan sonra ise kullanması kalıyor. Normalde her şeyi Expr
ile oluşturmayı seviyorum ancak kullanıcı tanımlı bu fonksiyonlar için Expr
ifadeleri bulunmuyor.
$qb = $this->createQueryBuilder('u');
$qb->andWhere(":role <> ANY_OF(u.roles)")
->setParameter('role','ROLE_ADMIN');
return $qb->getQuery()->getResult();
Yukarıda gördüğünüz gibi, sorgu olarak direkt kullanabiliyoruz.
Dikkat etmeniz gereken şey, PostgreSQL ifadelerinden bazıları DQL’de aynı isimde geçmiyor. PostgreSQL’de bulunan ANY
ve ALL
gibi fonksiyonları ANY_OF
ve ALL_OF
gibi DQL’e geçmiş olmasının sebebi, zaten DQL içerisinde ANY
ve ALL
adında iki fonksiyonun bulunması. Ama tabi ki amaçları bambaşka.