i s m a i l p e r i m . n e t
js, ajax, php, mysql, c#
js, ajax, php, mysql, c#
Oca 1st
Yeni yazımda sizlere geçenlerde keşfettiğim pratik bir işlemden bahsedeceğim.
Bahsettiğim işlem kimilerinize pratik, kimilerinize kullanışsız gelebilir. Karar sizin
İşleyiş şöyle oluyor;
Örneğin üyelik sistemi yapıyoruz. Basit anlamda ekleme silme ve düzenleme işlemlerine ihtiyacımız var. Bunun için öncelikle bir kullanıcı sınıfı oluşturuyoruz;
<?php class Kullanici { public $ID; public $KullaniciAdi; public $Sifre; public $EPosta; public $Adi; public $Soyadi; public $Sehir; public $Adres; public $PostaKodu; public $Telefon; public $WebSitesi; } ?>
basit anlamda kullanıcı özelliklerini tanımlıyoruz öncelikle. Daha sonra kullanıcı işlemlerini yapacak olan ekleme, silme, düzenleme fonksiyonlarını yazacağız.İşte bahsettiğim olayın pratikliği burada devreye giriyor. Normalde örneğin düzenleme işlemini yapan fonksiyon içinde düzenleme sorgusu için sorguyu metin olarak yazar, içine de eklenecek değişkenleri yazarız. Misal;
mysql_query("UPDATE kullanici SET adi = '$this->Adi WHERE id = '$this->ID' '");
şeklinde yazarız. 2 satır şey yazmaktan üşendiğim zaman keşfettiğim işlem sayesinde fonksiyon sınıf içinden property leri okuyarak sorguya dahil ediyor. Bu durumda yeni bir property eklediğimizde veya var olan property lerden birini sildiğimiz zamanlarda hem sınıf içinde değişiklik yapar, hemde sorguda değişiklik yaparız. Bu yöntem sayesinde sınıf propertysinde değişiklik yaptığımız zaman otomatik olarak sorguya yansıyor.
Bu işlemi yapabilmek için öncelikle işlemleri yaptığımız sınıfın propertylerini okumaya ihtiyacımız var. Bunun için;
print_r($this);
dediğimiz zaman $this ile varolan sınıfı object olarak alıyoruz. Bu object türündeki değişkenimizi işlemlerimiz için array türüne cast ediyoruz.
(array)$this;
Bir dizide var olan key isimlerine ulaşmak için ise array_keys() fonksiyonunu kullanıyoruz.;
$sinif = array_keys((array)$this); echo $sinif[0]; // Kullanıcı sınıfının 0. propertysi olan "ID" yi bize geri döner.
Yukarıdaki kod parçacığında ise sınıf property isimlerine erişmiş oluyoruz.
Basit bir döngü ile dizimizin içinde bir tur atarak işlem yapacağımız sorgumuzu rahatlıkla oluşturabiliyoruz.
Sonuç olarak ise ortaya kendi kendine sorgusunu yaratan basit bir fonksiyon ortaya çıkıyor;
public function Degistir() { if((int)$this->ID != 0) { $sorguMetin = 'UPDATE kullanicilar SET '; $sinif = array_keys((array)$this); for($i = 1;$i<count($sinif);$i++) { $sinifKucuk = strtolower($sinif[$i]); $sinifBuyuk = $this->{$sinif[$i]}; if($sinifKucuk == 'sifre') { if($sinifBuyuk != '') { $sinifBuyuk = md5(sha1($sinifBuyuk)); $this->Sifre = $sinifBuyuk; $sorguMetin .= " $sinifKucuk = '$sinifBuyuk'"; if($i<count($sinif)-1) { $sorguMetin .= ', '; } } } else { $sorguMetin .= " $sinifKucuk = '$sinifBuyuk'"; if($i<count($sinif)-1) { $sorguMetin .= ', '; } } } $sorguMetin .= " WHERE id = '$this->ID'"; mysql_query($sorguMetin); }
Nis 7th
artık birÅŸeyler paylaÅŸmanın zamanı geldiÄŸini düşündüm. uzun zamandır blogum boÅŸ boÅŸ dururken (: ÅŸimdi “internet dünyasına yararlı olabilcek birÅŸeyler paylaÅŸmak” zamanı geldiÄŸini düşündüm ve ilk olarak php ve sınıflara iliÅŸkin bir örnek hazırlamakla baÅŸlayayım dedim.
<?php //////////////////////////////////////////////////// // //   Code By ismailperim //   http://www.ismailperim.net //   http://www.ismailperim.com //   <ismailperim@gmail.com> // // //   Açıklama           : PHP ve Sınıflar // //////////////////////////////////////////////////// class ogrenci { // Öğrencinin Property'leri var $adi; var $soyadi; var $sinav1; var $sinav2; var $not; // Methodlar function adi_belirle ($n) { $this->adi = $n; } function soyadi_belirle ($n) { $this->;soyadi = $n; } function sinav1_belirle ($n) { $this->sinav1 = $n; } function sinav2_belirle ($n) { $this->sinav2 = $n; } function not_hesapla() { $this->not = ($this->sinav1 + $this->sinav2)/2; print ($this->adi. " " . $this->soyadi . " not ortalaması: ". $this->not); } } //Şimdi yeni bir sınıf türetelim $ogr1 = new ogrenci(); $ogr1 -> adi_belirle("ismail"); $ogr1 -> soyadi_belirle("perim"); $ogr1 -> sinav1_belirle(70); $ogr1 -> sinav2_belirle(100); $ogr1 -> not_hesapla(); // Sınıflar sayesinde bu örnekte birbirinin aynı özellikleri taşıyan bir çok öğrenciyi aynı sınıf altında toplayabilir, birbirinden bağımsız sınıflar türeterek her öğrenci için yapılması gereken işlemleri // yaptırabiliriz. ?>