Merhaba arkadaşlar,
Mobilhanem.com’ da yayınladığımız Codeigniter Dersleri setimize 6. yazımızla devam ediyoruz. Bu dersimizde Active Record nedir? ve Codeigniter’ da Veritabanı işlemleri gibi konulardan bahsedeceğiz.
Active Record nedir?
Kısaca Active record’ un ne olduğundan bahsedecek olursak, Active Record Codeigniter Framework’ ünde veritabanı işlemlerini kolaylaştıran bir araç diyebiliriz. Active record ile veritabanına DML (Data Manipulation Language) ve DDL (Data Defination Language) sorguları kolaylıkla gönderilebilmektedir.
Codeigniter’ da Veritabanı İşlemleri
Codeigniter’ da Veritabanı Kullanımı için Konfigürasyonlar
Codeigniter ile veritabanı işlemlerini yaparken ilk olarak codeigniter projemizde yapmamız gereken konfigürasyonlardan bahsedeceğim. Yapacağımız bu konfigürasyonlar sadece MySql Veritabanına bağlanma ile ilgili işlemleri içermektedir. Bunlar sırasıyla
- Application klasörü altındaki config klasörü altında bulunan database.php adlı dosyanın içine girilerek aşağıdaki resimde belirttiğim yerlerde düzenleme yapılır.
- Daha sonra application klasörü altındaki config klasörü altında bulunan autoload.php (Proje genelinde yüklenmesini istediğimiz Paketler, Modeller, Kütüphaneler, Helperlar, Konfigürasyonlar ve Diller gibi yapıların yazıldığı dosya) dosyaya girilerek autoload adlı dizi’ nin libraries indisine aşağıdaki gibi atama yapılır ve böylece database kütüphanesinin proje genelinde yüklenmiş olması sağlanır.
$autoload['libraries'] = array("database");
- Şimdi yapmamız gereken işlemler Mysql’ de mobilhanem adında bir veritabanı oluşturmak ve bunun içinde de egitmenler adında bir tablo olusturarak veritabanı işlemleri için son adımımızı gerçekleştirmek olacak. Yapacağım Tablonun yapısı aşağıdaki gibi olacaktır.
Bu yazımız veritabanı işlemlerine giriş yazımız olduğundan bu şekilde basit bir veritabanı tasarımı tercih ettim. Yapacağımız işlemleri DE (CRUD – Create – Read – Update – Delete) şimdilik sadece Welcome controller’ ında ve oluşturacağımız View’ dosyalarında yapacağız. Model dosyasının kullanımına bir sonraki dersimizde değineceğiz.
Listeleme işleminin yapılması
Bu işlem yapılırken veritabanı kütüphanesinde bulunan get metodu kullanılır. bu metod
$this->db->get("tablo_adi");
şeklinde kullanılır. Şimdi yaptığım örneği inceleyecek olursak,
<?php defined('BASEPATH') OR exit('No direct script access allowed'); class Welcome extends CI_Controller { public function index() { $satirlar=array(); $satirlar["egitmenler"]=$this->db->get("egitmenler")->result(); $this->load->view('egitmenler',$satirlar); } }
ilk olarak, $satirlar adında bir dizi oluşturduk. Sonra bu $satirlar adındaki dizinin egitmenler indisine select işlemi için kullandığımız database sınıfının get methodunu ve ardından da bize veritabanımızda bulunan kayıtların dizi olarak dönmesini sağlayacak result metodunu kullandık. Daha sonra çektiğimiz verileri oluşturmuş olduğum egitmenler adındaki View dosyasına gönderdim. Dikkat etmeniz gereken bir nokta result metodu bize dizi döndürür fakat dizi elemanlarını stdClass türünde bir nesne olarak döndürür. Bunu görmek için
<?php defined('BASEPATH') OR exit('No direct script access allowed'); class Welcome extends CI_Controller { public function index() { $satirlar=array(); $satirlar["egitmenler"]=$this->db->get("egitmenler")->result(); print_r($satirlar); die(); $this->load->view('egitmenler',$satirlar); } }
print_r metoduna $satirlar değişkeni parametre olarak geçip ardından da die metodu kullanılarak sonraki satırların çalışmasının önüne geçilir. Sayfayı yenilediğimizde ve sayfaya sağ tıklayıp sayfa kaynağını görüntüle dediğimizde karşılaştığımız görüntü aşağıdaki gibi olacaktır.
print_r metodu verilerimizin veri tabanından çekerken hata yapıp yapmadığımızı görmek için oldukça kullanışlı bir metoddur. Bu metodu aynı zamanda View dosyasında da kullanarak View’ e gönderdiğiniz verilerin gelip gelmediğini test edebilirsiniz. Print_r metodu ardından die metodunu kullanmanız sonraki kodların çalışmasını önleyeceği için daha net bir görüntü elde etmenizi sağlar. Yaptığımız bu işlemlerin ardından result metodu ile dönen dizi elemanlarının bir sınıfa ait nesne olduğunu gördük. Php’ de bildiğiniz üzere bir sınıfa ait özelliklere nesne ile ‘->’ notasyonu ile erişim sağlıyoruz. Bu yüzden View dosyasında nesne değişkenlerine erişirken ‘->’ kullanacağız. Bu işleme geçmeden önce print_r metodunu ve die metodunu index action’ u içinde silmeyi unutmayalım. Eğer silmezsek sayfayı ne kadar yenilersek yenileyelim sürekli aynı çıktı ile karşılaşmış oluruz. Şimdi ise $egitmenler dizisindeki verileri View dosyasında göstermek için yazmamız gereken View dosyası aşağıdaki gibi olmalıdır.
<!doctype html> <html lang="tr"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Eğitmenler Listesi</title> </head> <body> <table border="1" cellpadding="0" cellspacing="0"> <thead> <tr> <th>Id</th> <th>Ad - Soyad</th> <th>Yaş</th> <th>Açıklama</th> <th>Aktif</th> </tr> </thead> <?php foreach ($egitmenler as $egitmen){ ?> <tr> <td><?php echo $egitmen->Id ?></td> <td><?php echo $egitmen->fullname ?></td> <td><?php echo $egitmen->age ?></td> <td><?php echo $egitmen->description ?></td> <td><?php echo $egitmen->isActive ?></td> </tr> <?php } ?> </table> </body> </html>
Foreach döngüsü içinde de gördüğünüz üzere nesne özellilklerine ‘->’ nostasyonunu kullanarak erişiriyoruz. Bu işlemleri gerçekleştirdiğinizde karşılacağımız sayfa aşağıdaki gibi olacaktır.
Aktif sütununda 1 ya da 0 değerleri yerine text şeklinde çıktı vermek için
<td><?php echo $egitmen->isActive ?></td>
satırını
<td><?php echo $egitmen->isActive ==1? "EVET":"HAYIR" ?></td>
şeklinde değiştirirsek isActive değeri 1 ise EVET, 0 ise HAYIR şeklinde çıktı verecektir.
Ekleme işleminin yapılması
Insert işlemini yapmak için veritabanı kütüphanesinin insert metodunu kullanıyoruz. Kullanımı ise
$data=array( "fullname" => "Hasan GÖZTOK", "age" => 23, "description" => "Elektrik & Elektronik Mühendisi", "isActive" => 1 ); $this->db->insert("tablo_adi", $data);
gibidir. Veri eklemek için kullandığımız insert metodu yukarda ki kodda da gördüğünüz üzere verinin ekleneceği tablo adı ve eklenecek veri şeklinde 2 parametre alır. Kayıt ekleme işlemine geçmeden önce egitmenler.php adlı View dosyasında bizi ekleme işlemi yapacağımız sayfa götüren a elementiyle oluşturacağımız bir link ekleyelim. Yapılacak işlemden sonra View kodları ve egitmenler.php View dosyasındaki görüntü aşağıdaki gibi olacaktır.
<!doctype html> <html lang="tr"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Eğitmenler Listesi</title> </head> <body> <a href="<?php echo base_url("Welcome/get_add")?>">Yeni eğitmen ekle</a> <br><br> <table border="1" cellpadding="0" cellspacing="0"> <thead> <tr> <th>Id</th> <th>Ad - Soyad</th> <th>Yaş</th> <th>Açıklama</th> <th>Aktif</th> </tr> </thead> <?php foreach ($egitmenler as $egitmen){ ?> <tr> <td><?php echo $egitmen->Id ?></td> <td><?php echo $egitmen->fullname ?></td> <td><?php echo $egitmen->age ?></td> <td><?php echo $egitmen->description ?></td> <td><?php echo $egitmen->isActive ==1? "EVET":"HAYIR" ?></td> </tr> <?php } ?> </table> </body> </html>
Yukarda gördüğünüz kodlarda a elementinin href özelliğine base url kullanarak Welcome Controller’ ının get_add adındaki Action’ una gitmesini istedğimizi söyledik. Base_url metodu kullanımından ve kullanılabilmesi için yapılması gerek konfigürasyonlardan önceki derste bahsetmiştim. Şimdi ise sayfayı yüklemek istediğimizde karşılaşacağımız sayfa aşağıdaki gibi olacaktır.
Şimdi yapmamız gereken şey ise get_add adında bir Action ve bu Action’ un döndüreceği bir kayıt ekleme formu olacaktır. Bu action’ un döndüreceği View dosyasının adı egitmen_ekle.php olsun. Öncelikle get_add Action’ undan nasıl yazacağımdan bahsedecek olursam bu Action sadece bir View yükleme işlemi yapacak basit bir Action olacaktır.
public function get_add(){ $this->load->view("egitmen_ekle"); }
Yukarıdaki kodda da gördüğünüz üzere get_add Action’ u egitmen_ekle adında bir View dosyasını yüklemektedir. Şimdi ise egitmen_ekle.php adında bir View dosyası oluşturalım ve içinde bir egitmen ekleme işlemi için form tasarlayalım. Eğitmen ekleme formu View kodları ve sayfanın görüntüsü aşağıdaki gibi olacaktır. Bu sayfaya egitmenlerin listelendiği link ile ya da adres çubuğundan Welcome Controller’ ının get_add Actionuna giderek siz de sayfanın görünümünü görebilirsiniz.
egitmen_ekle.php View Dosyası Kodları
<!doctype html> <html lang="tr"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Eğitmek Ekle | Mobilhanem</title> </head> <body> <form action="<?php echo base_url("Welcome/post_add") ?>" method="post"> <b>Ad & Soyad</b> <br><input type="text" name="fullname"> <br><br> <b>Yaş</b> <br><input type="text" name="age"> <br><br> <b>Açıklama</b> <br><input type="text" name="description"> <br><br> <b>Aktif mi?</b> <br><input type="checkbox" name="isActive"> <br><br> <a href="<?php echo base_url("Welcome")?>">[ Vazgeç ]</a> <button type="submit">Ekle</button> </form> </body> </html>
Bu form Php ya da diğer Web Programlama dilleri ile Uğrştıysanız Çok ta yabancı olmayacağınız bir form sayfasıdır. Form elementinin Action özelliğinde ve Vazgeç linkinin (Bizi eğitmenler sayfasına dönderecek link) href özelliğinde base_url metodunu kullandık. Şimdi ise bu formdaki verileri post ettiğimiz verileri post_add Action’ umuzu Welcome Controller içinde oluşturalım ve bu Action’ un içinde post ettiğimiz verileri veritabanına ekleme işlemini gerçekleştirelim.
post_add Action Kodları
public function post_add(){ $eklenecek_veri=array( "fullname" =>$this->input->post("fullname"), "age" =>$this->input->post("age"), "description" =>$this->input->post("description"), "isActive" =>empty($this->input->post("isActive"))? 0:1, ); $insert=$this->db->insert("egitmenler",$eklenecek_veri); if ($insert>0){ redirect(base_url("Welcome")); //Ekleme işlemi başarılıysa egitmenler View' ine dönecek die(); }else{ redirect(base_url("Welcome/get_add")); // Ekleme işlemi başarısızsa ekleme sayfasında kalacaz die(); } }
Yukardaki kodları açıklayacak olursam, İlk olarak $eklenecek_veri adında bir diziye form verilerimizi veritabanında karşılık geldikleri kolonlara denk gelecek şekilde ekleme işlemini yapalım. İşimizi kolaylaştırsın diye egitmen_ekle.php dosyasında form elementlerinin name özelliklerini veritabanındaki kolon isimleriyle aynı yaptım. Bu işlemi hız kazanmanız açısından ve hata yapma ihtimalinizi azaltmanız açısından size de tavsiye ederim. Daha sonra $insert adındaki bir değişkene insert işleminin sonucunu atadık. Bu sayede $insert değişkenine işlem sonucunda etkilenecek satır sayısı atanacaktır ve bu sayede biz de işlemin başarılı olup olmadığını anlayabileceğiz. if ve else blokları içinde bulunan redirect metodu ise uri_helper adındaki helper’ da bulunan bir metoddur ve temelinde Php fonksiyonlarından olan header methodu yatar dolayısıyla, redirect metodu sayfalar arası yönlendirme işlemlerinde kullanılır. Redirect metodu altında kullanılan die metodunu kullanma sebebim ise localde bu problem olmasa da siteyi canlıya almak istediğinizde redirect metodu yönlendirme yapmadan hata ile karşılaşılabilmektedir. Şimdi ise sizle yazdığımız bu kodlar sonucunda karşılaşacağımız ekran çıktılarını paylaşacağım.
- Eğitmenler sayfasından Yeni eğitmen ekle linki ile eğitmen ekleme formuna gidilir ve sayfadaki form aşağıdaki gibi doldurulur, Form bilgileri doldurulduktan sonra Ekle butonuna tıklanır ve kayıt veritabanına eklenir.
- Ekle butonuna tıklandıktan sonra eğer bir hatamız yoksa karşılaşacağımız sayfa eğitmenlerin listelendiği sayfa olur ve yeni eklediğimiz kaydı da bu sayfada görmüş oluruz. Sayfanın çıktısı aşağıdaki gibidir.
Güncelleme ve Silme işlemleri için View düzenlemesi
Hepinizin de tahmin edebileceği gibi güncelleme ve silme işlemleri için egitmenlerin listelendiği tablonun ufak bir değişikliğe ihtiyacı var. Bu değişiklileri yaparken Güncelleme ve silme işlemini yaparken işlemleri yapacağımız Action’ a eğitmenlerin Id bilgisini göndermemiz gerekmektedir. Action’ a Id gönderme işlemini listelenen her eğitmene ait a elementlerinin (Silme ve Güncelleme) href özelliğinde gerçekleştireceğiz. Yapacağım View tasarımının kodları ve çıktışı aşağıdaki gibi olacaktır.
<!doctype html> <html lang="tr"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Eğitmenler Listesi</title> </head> <body> <a href="<?php echo base_url("Welcome/get_add")?>">Yeni eğitmen ekle</a> <br><br> <table border="1" cellpadding="0" cellspacing="0"> <thead> <tr> <th>Id</th> <th>Ad - Soyad</th> <th>Yaş</th> <th>Açıklama</th> <th>Aktif</th> <th>İşlemler</th> </tr> </thead> <?php foreach ($egitmenler as $egitmen){ ?> <tr> <td><?php echo $egitmen->Id ?></td> <td><?php echo $egitmen->fullname ?></td> <td><?php echo $egitmen->age ?></td> <td><?php echo $egitmen->description ?></td> <td><?php echo $egitmen->isActive ==1? "EVET":"HAYIR" ?></td> <td> <a href="<?php echo base_url("Welcome/delete/$egitmen->Id")?>">[ Sil ]</a> <a href="<?php echo base_url("Welcome/get_update/$egitmen->Id")?>">[ Güncelle ]</a> </td> </tr> <?php } ?> </table> </body> </html>
Güncelleme işleminin yapılması
Güncelleme işlemi kısmen de olsa Ekleme işlemine benzemektedir. Güncelleme formunu tasarlarken Ekleme formunu baz alacağız ve bir iki ufak detay dışında formlar neredeyse aynı olacak diyebiliriz. Güncelleme formunun yüklenmesi için get_update adında ve Id değerini parametre alan bir Action yazmamız ve Id verisi ile güncellenmek istenen eğitmene ulaşıp bu eğitmene ait verileri güncelleme formuna yüklememiz gerekmektedir yani sayfayı yüklerken View’ e eğitmenin bilgilerini göndereceğiz. get_update Action’ una ait kodları adım adım yazacak olursak ilk olarak güncellenecek eğitmeni bulacak kodu yazmamız gerekir.
public function get_update($id){ $guncellenecek_egitmen=$this->db->where("Id",$id)->get("egitmenler")->row(); print_r($guncellenecek_egitmen); die(); //$id 3 ise çıktı => stdClass Object ( [Id] => 3 [fullname] => Vehbi AKDOĞAN [age] => 24 [description] => Php Dersleri Yazarı [isActive] => 1 ) }
olacaktır. Yukardaki kodda da dikkatinizi çekmiştir şu ana kadar kullanmadığımız where ve row adında 2 metod kullandık. Where sorgularımızda koymak istediğimiz şartlar için kullanılırken, row ise yapılan sorgulama sonucu dönen ilk satırı çeker. Yani row sonucu bir liste değil de stdClass türünde bir nesne döner. Şimdi yapmamız gereken $egitmen verisini View’ e geçmek. Bunun için de,
public function get_update($id){ $guncellenecek_egitmen["egitmen"]=$this->db->where("Id",$id)->get("egitmenler")->row(); $this->load->view("egitmen_guncelle",$guncellenecek_egitmen); }
şeklinde $egitmen verisi View’ e gönderilir.
egitmen_guncelle View dosyasının tasarımı
Bu sayfanın tasarımında Ekleme formunu bire bir kopyalayıp ufak değişiklikler yapacağım. Yapacağım değişiklikler,
- Form içinde type özelliği hidden olan input elementinin içinde Eğitmene ait Id değerini saklamak.
- Form elementin action metodunun update işlemi için güncellenmesi.
- Form inputlarının value özelliğine View’ e gönderilen eğitmene ait verilerin yazılması
gibi olacaktır.
View dosyasına ait kodlar aşağıdaki gibidir.
<!doctype html> <html lang="tr"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Eğitmen Güncelle | Mobilhanem</title> </head> <body> <form action="<?php echo base_url("Welcome/post_update") ?>" method="post"> <input name="Id" type="hidden" value="<?php echo $egitmen->Id?>"> <b>Ad & Soyad</b> <br><input type="text" name="fullname" value="<?php echo $egitmen->fullname?>"> <br><br> <b>Yaş</b> <br><input type="text" name="age" value="<?php echo $egitmen->age ?>"> <br><br> <b>Açıklama</b> <br><input type="text" name="description" value="<?php echo $egitmen->description ?>"> <br><br> <b>Aktif mi?</b> <br><input type="checkbox" name="isActive" <?php echo $egitmen->isActive==1? "checked":""?>> <br><br> <a href="<?php echo base_url("Welcome")?>">[ Vazgeç ]</a> <button type="submit">Güncelle</button> </form> </body> </html>
Şimdi ise güncelleme işlemini yazacağız ve güncelleme formundan post_update Actionuna gönderilen verileri kullanarak eğitmenimize ait verileri güncelleyeceğiz.
post_update Action’ una ait kodlar aşağıdaki gibidir.
public function post_update(){ $guncellenecek_veri=array( "Id" =>$this->input->post("Id"); "fullname" =>$this->input->post("fullname"), "age" =>$this->input->post("age"), "description" =>$this->input->post("description"), "isActive" =>empty($this->input->post("isActive"))? 0:1, ); $update=$this->db->where("Id",$guncellenecek_veri["Id"])->update("egitmenler",$guncellenecek_veri); if ($update>0){ redirect(base_url("Welcome")); die(); }else{ redirect(base_url("Welcome/get_update/".$guncellenecek_veri["Id"])); die(); } }
post_update Action’ undaki kodlar da genel hatlarıyla post_add Actionunda ki kodlara benzemektedir. Yaptığımız veritabanı kütüphanesindeki update metodunu kullanmak ve where şartında güncellenecek eğitmene ait Id’ yi parametre vermek. Bu işlemin de sonucu $update değişkenine atandı ve duruma göre yönlendirmeler yapıldı. Else koşulundaki yönlendirme işlem başarısız olduğun da ya da bilgilerde bir güncelleme yapmadığımızda çalışır ve aynı sayfada kalmamızı sağlar.
- Egitmenlerin Listelendiği sayfada bir eğimenle aynı satırda bulunan güncelleme linkine tıklanır ve aşağıdaki sayfa ile karşılaşılır.
- Eğitmen Bilgilerinde aşağıdaki resimdeki gibi değişiklikler yapılır
- Güncelleme işleminin sonucu
Silme işleminin yapılması
Silme işlemi yapmış olduğumuz, Listeleme, Ekleme ve Güncelleme işlemlerinden daha kolay bir şekilde gerçekleşmektedir. Daha kolay deme sebebim View tasarımı gerektirmemesidir. Silme işlemi yaparken veritabanı sınıfına ait delete metodunu kullanacağız. Sil linki bizi Welcome Controller’ ı içindeki delete adındaki Action’ a yönlendirmektedir. Dolayısıyla şimdi Welcome Controller’ ı içinde delete Action’ u yazıp silme işlemlerini yapacağız.
delete Action’una ait kodlar aşağıdaki gibidir.
public function delete($id){ $delete=$this->db->where("Id",$id)->delete("egitmenler"); if ($delete>0){ redirect("Welcome"); }else{ echo "Silme işleminde hata..."; } }
Bu Action da silme işleminin sonucu $delete adındaki değişkene atanmıştır. Silme işlemi başarılı olduysa etkilenen satır sayısı 0′ dan büyük olacağından aynı sayfa yenilenecek ve silinen kayıt sayfada gözükmeyecektir. Eğer kayıt silinmezse ekrana Silme işleminde hata… yazdırılacaktır. Deneme amaçlı kendime ait kaydı sildiğimde karşılaşacağımız çıktı aşağıdaki gibi olacaktır.
Codeigniter Dersleri eğitim setinin 6. yazısını burada noktalıyorum. Bu yazımızda Active Record nedir? ve Codeigniter’ da Veritabanı işlemleri gibi konulardan bahsettik. Konu ile ilgili sorularınızı Mobilhanem Soru&Cevap bölümünden sorabilirsiniz. Makarna kod yazmamak için framework kullanalım dedik ve veritabanı işlemlerini Controller içinde yazarak ne yazık ki makarna kod yazdık. Bu yüzden sonraki derste Model dosyası kullanımı ve veritabanı işlemleri ile devam edeceğiz
Tüm Codeigniter Dersleri‘ ne buradan ulaşabilirsiniz.
2