Aramayan Bulamaz
×

PHP de veri tabanına bağlanma ve sorgu çalıştırmayı anlatmıştım.
Klasik veri tabanı bağlantısı mysql_connect() komutu ile yapılıyor, sorgu çalıştırma mysql_query() ile yapılıyor fakat pdo yapısı biraz farklı. PDO php 5.2 den sonra gelen bir veri tabanı sorgu sınıfı, yani nesne tabanlı bir yapı.
En güzel özelliği çoklu veri tabanı desteği olması. Oracle, SQL Server, MySQL gibi farklı veritabanlarına bağlanabilme özelliği sunuyor. Ayrıca kendi içerisinde sql injection koruması olan bir sınıftır.

 
$db = new PDO('mysql:host=localhost;dbname=veritabanı adı', 'kullanıcı adı', 'sifre');
 
PDO sınıfını db değişkenine bağlı olarak oluşturduk, sorgularımızı bu sınıfa bağlı methodlar ile yapacağız.

query() methodu genel olarak tüm sorgularda kullanılır.
exec() methodu bilgi girişi, güncelleme, silme gibi veri tabanına değer göndermede kullanılır.
prepare() methodu query() methodundaki gibi tüm sorguları çalıştırmada kullanılır fakat buna ek olarak bir de execute() methodu kullanılır, prepare ile yapılan sorgunun uygulanması için.
fetch() methodu; tek bir sonuç getirmek için kullanılır, query ile çalıştırılmışsa sorgu query den sonra, prepare ile çalıştırılmışsa sorgu execute methodundan sonra kullanılır.

Veritabanından dataların sayılarını getirmek istediğimizde fetch(PDO::FETCH_NUM) kullanılır.

Örnek olarak bir sorgu çalıştırayım, sorguyu query ile yapacağım.
 
$sorgu = $db->query('select * from blog where id=1')->fetch();
 
Veritabanından id değeri 1 olan konuyu getiren sorguyu yazdık. Bu şekilde de yapabilirdik
 
$sorgu = $db->query('select * from blog where id=1'); 
$sorgu->fetch();
 
İkisi de aynı işlemi yapıyor.
echo $sorgu['blog_baslik'];

İle konu başlığını yazdırmış oluruz.

Tüm konuların toplam sayılarını yazdırmak için
 
$konusayi = $db->query('select count(*) from blog')->fetch(PDO::FETCH_NUM);
echo $konusayi[0];
 
$konusayi değişkeni dizi tipinde bir değişken olduğu için $konusayi[0] şeklinde yazdırdık.


prepare() ile yaparsak eğer sorgumuz aşağıdaki gibi olacaktır;
 
$sorgu = $db->prepare('select * from blog where id=1');
$sorgu->execute();
$sorgu->fetch();
echo $sorgu['blog_baslik'];
 

Dışarıdan alınacaksa id bilgisi bunu parametre ile vermek daha iyidir, çünkü parametreyi tanımlarken o parametrenin integer veya string olma özelliğini kontrol ettirebiliyoruz. Parametre için bindValue() methodunu kullanıyoruz.
 
$sorgu = $db->prepare('select * from blog where id=:id');
$sorgu->bindValue(':id', $id, PDO::PARAM_INT);
$sorgu->execute();
$sorgu->fetch();
echo $sorgu['blog_baslik'];
  
Sorgumuzu yazarken :id kullandım, bu parametre, bunun değerini bindValue() methodu ile aktardım.
PDO::PARAM_INT ile gelecek değerin int tipinde olacağını belirttik.

Gelecek olan değerin string olması ile ilgili bir kontrol yaptıracaksak eğer PDO::PARAM_STR yazmalıyız INT yerine.

Şimdiye kadar veritabanından hep bilgi getirdik, aynı sorgularla insert, update, delete işlemleri de yapabiliriz.

Delete, update gibi işlemler için exec kullanabiliriz, ayrıca veri tabanı karakter seti belirleyeceksek yine exec kullanmalıyız.
 
$sorgu = $db->exec('delete from blog where id=1');
 
Blog id değeri 1 olan konuyu sildik. Fakat bu tarz işlemleri prepare ile yaparsak daha iyi olur.

Veya karakter seti ayarlayacaksak eğer
 
$db->exec("set names 'utf8'");
bu sorguyu kullanmalıyız.

Bunları da okumak isteyebilirsiniz

7 Yorum

image

Ömer

24 Ağustos 2013 19:33

çoklu veritabanı desteğinden bahsetmişsiniz fakat mysql haricinde diğerlerine nasıl bağlanabileceğimizi anlatmamışsınız, diğer veritabanlarında nasıl sorgu çalıştırabiliriz?

image

Cryptograph

24 Ağustos 2013 20:11

Diğer veritabanlarında sorgu çalıştırma yine aynı komutlarla yapılıyor fakat veritabanı bağlantısı yapmak için connection stringi değiştirmemiz gerekiyor. Mesela PostgreSQL için

$db = new PDO("pqsql:host=localhost dbname=veritabanıadı ,'kullanıcı adı','sifre');

şeklinde yapabiliriz. Diğer veritabanları için olan connection stringleri bilmiyorum MySQL harici bir veritabanıyla çalışmadım hiç. Ayrıca bağlantı yaptığımızda bu bağlantının açılıp açılmadığını try - catch komutlarıyla kontrol ettirebiliriz. Bu sayede ekrana bizim istediğimiz hata mesajı yazdırılmış olur.

try{
$sorgu = $db->query('select * from blog where id=1')->fetch();
}
catch (PDOException $e){
echo 'Bağlantı hatası, hata kodu: '.$e->getMessage();
}

PDO ile ilgili ayrıntılı bilgi için buraya bakabilirsiniz.

image

Kadir Malakcıoğlu

23 Ekim 2013 06:52

Merhaba sormak istediğim 2 şey var

1. prepare kullanırken bindValue metodu kullanılıyor diyelim ki göndereceğimiz 2 tane değişken var biri integer diğeri ise string içeriyor . ne yazpmalıyız

image

Kadir Malakcıoğlu

23 Ekim 2013 06:54

karakter sınırlandırması olduğundan 2 mesajı tekrar gönderiyorum. prepare metodu ile birden fazla veri çekmek istiyorum nasıl yaparım

image

Cryptograph

23 Ekim 2013 16:49

Göndereceğiniz her değer için tekrardan bindValue() kullanmanız gerekiyor

$sorgu->bindValue(":string", $string, PDO::PARAM_STR);
$sorgu->bindValue(":int", $int, PDO::PARAM_INT);

Şeklinde bir kullanımla birden fazla değeri gönderebilirsiniz.

prepare() ile birden fazla tablodan veri çekecekseniz eğer o tablolar arasında ilişki kurup almanız gerekecek yani inner join sorgusu çalıştırmanız gerekecek. İki tablo arasında bir ilişki bulunmuyorsa eğer ayrı ayrı sorgu çalıştırmanız gerekecek.

image

Kadir Malakcıoğlu

24 Ekim 2013 04:18

hocam yanlış anlaşıldı maalesef siz demişsiniz ki "fetch() methodu; tek bir sonuç getirmek için kullanılır, " ben de diyorum ki 1den fazla sütün getiriyorum foreach yardımı ile acaba yanlış bir yol mu izliyorum ayrıca gelen veriyi nesne şeklinde nasıl alabiliriz kullanabiliriz şimdiden teşekkürler

image

Cryptograph

24 Ekim 2013 04:45

Evet döngü kullanırsanız döngü boyunca birden fazla değer getirebilirsiniz. Döngünün amacı budur zaten :)
Kullanımızda yanlış bir şey yoktur.

Sen de bir yorum bırak