MyObjects Php 5 - MySql Nesne Köprüsü 1.0 Beta 2 Yayınlandı

0
angeleous
Aslen Zend'in PHP 5 programlama yarışması için geliştirdiğim ve BSD lisansıyla dağıtılan MyObjects PHP 5 kütüphanesi ve araçlarının beta 2 sürümü çıktı. İlk defa Fazlamesai.net'de duyurduğum bu araç kitinin özellikleri kısaca şöyle:

Program benim gibi web projelerinde PHP dilini kullanan ve PHP 5'in gelişmiş nesne modelinden faydalanarak MySQL veritabanındaki kayıtlarını nesneler aracilgiyla yönetmek/görüntülemek isteyen programcılar için geliştirildi. Programın tam olarak 'Object Persistance' ya da 'Object Relational Mapping' tanımlarına akademik olarak uyduğunu söyleyemem. Programı yalnızca program yazarken kendi ihtiyaç duyduğum niteliklerden yola çıkarak geliştirdim.
MyObjects birkaç farklı kısımdan oluşuyor. Birinci kısım veritabanı yapınızı tasarlamanızı (Web arayüzü ile) ya da daha önceden oluşturulmuş bir veritabanının şemasını bir XML dosyasına aktarmanıza yarıyor. İkinci kısım oluşturulan XML formatındaki veritabanı şema dosyasını kullanarak veritabanınızdaki tablolara karşılık gelen PHP sınıflarını oluşturuyor. Son kısım ise oluşturulan PHP sınıfları ile birlikte kullanabileceğiniz çalışma zamanı sınıflarında oluşuyor. Bu sınıflar vasıtasıyla nesnelerin veritabanından veri alınarak oluşturulması, veritabanına kayıt edilmesi ya da kaydın güncellenmesi, nesnelerin XML dosyasına dökülebilmesi ya da XML dosyalarından yeniden bu nesnelerin oluşturulması mümkün oluyor.

MyObjects veritabanı şeması dosyasının oluşturulması, PHP sınıflarının üretilmesi safhasında kullanabileceğiniz komut satırı üzerinden kullanılabilen bir araç ve gelişmiş web arayüzü ile birlikte geliyor. Web arayüzü sayesinde bir MySQL veritabanını tasarlayabiliyor, tasarladığınız veritabana ait SQL çıktısını alabiliyorsunuz.

MyObjects'in en önemli özelliklerinden biri de veritabanı şeması dosyasında yalnızca veritabanınızın teknik özellikleri hakkında değil tablolarınızdaki alanlar ile ilgili sınırlayıcı bilgiler de girebilmeniz. Örneğin Kullanıcılar isimli tablonuzdaki email alanına en fazla 255 karaktere kadar olan geçerli email adreslerini kaydetmek, ve aynı email adresinin birden fazla kez kaydolmasını engellemek istiyorsanız ilgili bilgileri veritabanı şeması dosyasında tanımlayabiliyorsunuz. Böylece ilgili onaylama (validasyon) kodu oluşturulan PHP sınıflarina ekleniyor ve nesnelerinizin hatalı veriler ile doldurulmasını önlüyorsunuz. Hata denetiminde de PHP 5'in yeni "exception handling" mekanizması size yardımcı oluyor. Herhangi bir yanlış değer nesne özelliği olarak atanmak istendiğinde bir "exception" üretiliyor.

MyObjects PHP 5 ve MySQL 4.1 için yazılan yeni "ext/mysqli" eklentisini kullanıyor. Şu an için yeterli olmasa da MySQL 4.1 ile birlikte gelen stored procedure'lere de destek veriliyor.

Programcılar için işleri kolaylaştıracak bir başka nitelik ise oluşturulan PHP sınıflarının içerisine PHPDoc stili açıklamaların eklenmesi. Bu sayede oluşturulan sınıflara ait dokümantasyon PhpDoc aracı ile kolayca oluşturulabiliyor.

Henüz beta aşamasında olan bu proje Zend PHP 5 yarışmasına gönderildi ve şu an itibariyle onay bekliyor. Projenin ana sayfası İngilizce olarak yayın yapıyor ve dokümantasyonu içeriyor. Proje kodlarina ise SourceForge proje sayfasından ulaşabilirsiniz.

Dokümantasyon şu an itibariyle pek yeterli değil. Cookbook tarzı bir kullanım klavuzu hazırlama çalışmalarına başlamak üzereyim. Proje Zend firmasından onay alıp yarışma sayfasında yer aldığında oylarınızla destek olursanız sevinirim.

Teşekkürler, Erdinç Yılmazel

Editörün notu: Bu haberi düzenlerken deASCIIfier sistemi ile işimi kolaylaştıran tspell projesine teşekkürü bir borç bilirim. (Başka bir deyişle: TÜRKÇE KARAKTER KULLANSANIZA KARDEŞİM! :)
PHP

Görüşler

0
angeleous
Türkçe karakter konusunda çok özür dilerim, haberi gönderdiğim bilgisayarda Türkçe karakter yoktu. Bu arada tspell projesinin deasciifier ve asciifier yazılımlar gerçekten çok faydalı.
0
FZ
Sorun değil, acar FM editörleri her türlü otomasyon teknolojini dibine dek kullanmak sureti ile yazarlarına ve okuyucularına hizmet etmek için canla başla çalışıyor. Yarışmada başarılar!
0
angeleous
Beta 2 kodunu iceren zip paketindeki kodda bir Class isminin yanlis yazildigini farkettim, bu nedenle yaptigim baska degisikliklerle birlikte beta 2.1'i yayinladim. Beta 2'yi cekenlerin beta 2.1 [prdownloads.sourceforge.net]'i edinmelerini rica ederim.
Görüş belirtmek için giriş yapın...

İlgili Yazılar

Php.YeniDünya

butch

Php dili kullanılarak ilk bilgisayar virüsü yazıldı. Pek zararlı olmayan bu virüs şu anda sadece windows makinaların c:windows dizini altındaki .php, .hm, .html, .htt dosyalarını etkileyebiliyor. Ama yakın gelecekte daha gelişmiş türlerini görmemiz mümkün. Peki bunun anlamı nedir? Bu gelişme, yeni nesil virüslerin yolda olduğunun ilk habercisi. Unutmadan virüsün adı PHP.NewWorld yani PHP.YeniDünya. Detaylı bilgi

PHP Türkçe Kılavuzu

javamorg

Php.net Türkçe kılavuzu 26 Aralık'tan itibaren yayınlamaya başladı.

Vty - Mysql ve Mssql için Php tabanlı Veritabanı Yönetici

pieycpi

Mysql ve Mssql'i web üzerinden yönetmek kullanacağınız Vty scriptinin kullanılabilir ilk versiyonu çıktı. Vty ile mysql ve mssql database'i üzerinde istediğiniz işlemi web tabanlı olarak yapabilirsiniz.
Vty hakkında daha fazla bilgi almak ve Vty'yi download etmek için: www.kutukutu.com/vty

GNU/Linux Üzerinde de Çalışabilen Güzel Bir PHP Editörü: QUANTA 3.1

sceylani

Merhaba,

Linux için güzel bir editör bulma calışmalarım sonunda meyvelerini verdi :

Ekran Görüntüsü

Evet yukarıdaki ekran görüntüsünden de anlaşılacağı gibi GNU/Linux ile ücretsiz bir editör kullanılarak sayfa çıktılarının anında görülmesi ve bir nevi hata ayıklama (debug) işlemi mümkün olabiliyor.

linux üzerindeki php ile mssql 2000(veya 7.0 veya 6.5...)e bağlanmak istersek

roots

İlla da MySQL kullanacak değilsiniz ya, roots kardeşimiz bize PHP connectivity konusunda bir tecrübesini aktarmış.

Allah oldurmasın ama bir gün icap ederde başınız sıkışırsa ve siz mssql 2000'e linux üzerinde çalışan bir webserverdan php ile bağlanmak zorunda kalırsanız aşağıdakiler sanırım işinize yarayacaktır.

http://www.freetds.com'dan güncel tds sürümünü çekelim. RPM çekebilirsiniz kolay çözüm olarak. Ben tgz olarak indirdim ve...