Alfabetik Sıralama :ABCDEFGHIJKLMNOPQRSTUVWXYZ -


Böylece, MySQL ile bir veritabanı dosyası oluşturma işlemi bitmiş oldu. bir PHP programı yazarak bu veritabanındaki kayıtları okutabiliriz. Bunu yapmadan önce yine hızlı şekilde PHP-MySQL ilişkisinini sağlayan fonksiyonlara gözatalım.

PHP programlarımızda veritabanından yararlanabilmek için programın önce Web sunucusu aracılığıyla veritabanı dosyası ile bağlantı kurması gerekir. Başka bir deyişle, PHP programının veri ile arasında bir yol açması gerekir. MySQL açısından ise bu bağlantı, veri sunucusunda yeni bir oturum açılması anlamına gelir. İki program arasındaki bu ilişkiyi PHP`nin mysql_connect() fonksiyonu yapar. Bu fonksiyonun alabileceği üç parametre vardır:

php:
$veri_yolu = mysql_connect ("localhost" , "root" , "parola" );


Burada "localhost" yerine MySQL programının parçası olarak çalıştığı sunucunun adı yazılır. "root" bu MySQL sunucusunda açılacak oturumun kimin adına açılacağını belirter. "root" kelimesi, sunucunun yönetici olarak oturum açılacağı anlamına gelir: "parola" kelimesinin yerine de MySQL`i kurarken belirlediğimiz bir kullanıcı parolası varsa, onu yazarız. Bu komutta yer alan $veri_yolu değişkeni, açılacak veri yolunun, PHP ile MySQL veritabanı sunucusu arasındaki bağın tanıtıcı işareti olacaktır. Bu bağlantı kurulduktan sonra, açtığımız veri yolundan gelecek bilgiler ve veritabanına gidecek bilgiler bu değişken aracılığıyla gerçekleşecektir. Veri sunucusu ile veri yolu bağlantısı kurulursa, bu değişken değer tutar hale gelir; bağlantı kurulamazsa bu değişken boş kalır. mysql_connect() fonksiyonunun başarılı olup olmadığını bu değişkenin durumunu sınayarak anlayabiliriz. Örneğin:

php:
$veri_yolu =mysql_connect("kara-murat", "root");

if ( ! $veri_yolu) die ("MySQL ile veri bağlantısı kurulamıyor!);


Burada veri sunucusunun bulunduğu Web sunucusunun adının "kara-murat" olduğuna, ve ooturumun "root" yetkileriyle açıldığına dikkat edin. İkinci satırdaki if deyimi, $veri_yolu değişkeninin değer içerip içermediğine bakıyor ve değişkende bir değer yoksa, bağlantı kurma girişini durdurarak, ziyaretçiye hata mesajı gönderiyor.

Bağlantı başarıyla kurulduktan sonra PHP programı, bu yoldan, veritabanı sunucusuna, hangi veritabanı dosyasından yararlanmak istediğini bildirmelidir. Buna veritabanı dosyası seçme işlemi denir ve mysql_select_db() fonksiyonu ile yapılır:

php:
mysql_select_db( "veritabanın_adı" , $veri_yolu ) or die ("Veritabanı açılamıyor!".mysql_error() );


Bu fonksiyonun başarıyla icra edilip edilmediği fonksiyondan dönen değerin true/doğru veya false/yanlış olmasından anlarız. Bu değer false ise bu deyimin die() bölümü icra edilecek ve Browser penceresine veritabanının açılamadığı mesajıyla birlikte MySQL`in hata mesajı da gönderilecektir. PHP`nin MySQL veritabanını seçememesi çoğu zaman kullanıcı yetkilerinin Internet ziyaretçilerini kapsayacak şekimde düzenlenmemiş olmasından kaynaklanır. Bu durum gerçek Web sunucusunda ortaya çıkarsa, Web sunucusu yönetimine başvurmak gerekir.

Şimdi bu anlattıklarımızı biraraya getiren kolay bir PHP programıyla biraz önce oluşturduğumuz "veri" adlı veritabanından bir birinci kişiye ait verileri "okutarak, HTML sayfamızda kullanalım. Aşağıdaki programı, veri_01.php adıyla kaydedelim:

php:
<HTML>

<TITLE>PHP ile Veri Örnegi</TITLE>

<meta http-equiv="content-type" content="text/html; charset=ISO-8859-9">

</HEAD>

<BODY>

<?php

$veri_yolu = mysql_connect("kara-murat", "root");

if ( ! $veri_yolu ) die ("MySQL ile veri bağlantısı kurulamıyor!");

mysql_select_db("veri" , $veri_yolu)

or die ("Veritabanına ulaşılamıyor!" . mysql_error() );

$sonuc = mysql_query("SELECT * FROM calisanlar",$veri_yolu);

printf("Adı: %s<br>n", mysql_result($sonuc,0,"adi"));

printf("Soyadı: %s<br>n", mysql_result($sonuc,0,"soyadi"));

printf("Adresi: %s<br>n", mysql_result($sonuc,0,"adres"));

printf("Görevi: %s<br>n", mysql_result($sonuc,0,"pozisyon"));

?>

</BODY>

</HTML>


Burada, mysql_connect() fonksiyonu ile "kara-murat" isimli sunucuda root adına MySQL sunucu ile bağ kurduktan sonra mysql_select_db() fonksiyonu ile bu bağı kullanarak veri isimli veritabanından veri çekeceğimizi bildiriyoruz. Daha sonra mysql_query() fonksiyonu ile bu veritabanındaki “calisanlar” isimli tablodan “herşeyi” seçiyoruz ve seçilenleri $sonuc dizi-değişkeninde topluyoruz. $sonuc değişkenin değerlerini görüntülemek için PHP`nin özel bir fonksiyonu olan mysql_result() fonksiyonu kullanıyoruz. Burada metin biçimlendirmekte yararlandığımız printf() fonksiyonunu daha önce tanımıştık.
mysql_query() fonksiyonu, PHP`nin SQL dilini kullahnarak veritabanı işlemleri yapmasını sağlayan başlıca aracıdır. Yukarıda kısaca değindiğimiz bütün SQL komutlarıyla yazacağımız bütün "query" deyimlerini bu fonksiyon ile icra ettireceğiz. mysql_result() ise SQL değil, Data Manipulation Language (DML) denen başka bir veri-biçimlendirme dilinin inceliklerinden yararlanmamızı sağlar. Burada $sonuç değişkeninde veritabanı kayıt biçiminde tutulan verileri PHP`nin ve dolayısıyla HTML`in anlayacağı biçime çeviren bu fonksiyondur.

Şimdi bu programı biraz geliştirilim ve daha önce kendi kendine bilgi veren Form örneğimizi buraya uygulayalım; ancak bu kez, ziyaretçimizin vereceği bilgileri veritabanına ekleyelim; ve kendi adının veritabanına eklendiğini sayfadaki tabloyu güncelleyerek bildirelim. Önce şu programı, veri_02.php adıyla kaydedelim:
php:
<?php

// Form doldurulduktan sonra program buradan başlıyor

if ( isset ( $HTTP_POST_VARS )) {

$veri_yolu = mysql_connect("server", "root");

if ( ! $veri_yolu ) die ("MySQL ile veri bağlantısı kurulamıyor!");

mysql_select_db("veri" , $veri_yolu) or die ("Veritabanına ulaşılamıyor!" . mysql_error() );

$ekle = mysql_query("INSERT INTO calisanlar ( adi , soyadi , adres , pozisyon ) VALUES (`$adi`, `$soyadi`, `$adres`, `$pozisyon` )", $veri_yolu );

echo ("

<HTML>

<HEAD>

<TITLE>PHP`de Veritabanı</TITLE>

<meta http-equiv=`content-type` content=`text/html; charset=ISO-8859-9`>

"
);

$sonuc = mysql_query("SELECT * FROM calisanlar", $veri_yolu);

echo ("

<TABLE>

<TR>

<TD><B>Uzmanın Adı</B></TD>

<TD><B>Çalıştığı Yer</B></TD>

<TD><B>Görevi</B></TD>

</TR>

n"
);

while ($satir = mysql_fetch_row($sonuc)) {

printf("<TR><TD>%s %s</TD><TD>%s</TD></TD><TD>%s</TD></TR>n", $satir[1], $satir[2], $satir[3], $satir[4]);

}

echo ("

</TABLE>n

<p><B>Teşekkür ederiz.</B></P>

<A HREF=`index.php`>Ana sayfaya dönmek için tıklayınız</A>

"
);

}

// program ilk kez açılıyorsa buradan başlayacak

else {

echo ("

<HTML>

<HEAD>

<TITLE>PHP`de Veritabanı</TITLE>

<meta http-equiv=`content-type` content=`text/html; charset=ISO-8859-9`>

</HEAD>

<BODY>

<p><B>Mevcut Üyelerimiz</B></P>

"
);

$veri_yolu = mysql_connect("server", "root");

mysql_select_db("veri", $veri_yolu);

$sonuc = mysql_query("SELECT * FROM calisanlar", $veri_yolu);

echo ("<TABLE>

<TR>

<TD><B>Uzmanın Adı</B></TD>

<TD><B>Çalıştığı Yer</B></TD>

<TD><B>Görevi</B></TD>

</TR>

n"
);

while ($satir = mysql_fetch_row($sonuc)) {

printf("<TR><TD>%s %s</TD><TD>%s</TD></TD><TD>%s</TD></TR>n", $satir[1], $satir[2], $satir[3], $satir[4]);

}

echo ("

</TABLE>n

<p></p>

<p><B>Siz de aramıza katılmak ister misiniz?</B></P>

<FORM ACTION=`$PHP_SELF` METHOD=`POST`>

<TABLE>

<TR><TD>Adınız: </TD><TD><INPUT TYPE=`TEXT` NAME=`adi`></TD></TR>

<TR><TD>Soyadınız: </TD><TD><INPUT TYPE=`TEXT` NAME=`soyadi`></TD></TR>

<TR><TD>İş Yeriniz: </TD><TD><INPUT TYPE=`TEXT` NAME=`adres`></TD></TR>

<TR><TDALIGN=`left`>Göreviniz: </TD><TD><INPUT TYPE=`TEXT` NAME=`pozisyon`></TD></TR>

<TR><TD ALIGN=`center`><INPUT TYPE=`SUBMIT` VALUE=`Defteri imzala!`></TD><TD ALIGN=`center`><INPUT TYPE=`RESET` VALUE=`Tümünü sil!`></TD></TR>

</TABLE>

</FORM>

</BODY>

</HTML>

"
);

}

?>


Program, ilk kez çalıştığında, çalışmaya ikinci yarısındaki else() deyiminden itibaren icra ediliyor; ziyaretçilerimize mevcut üyelerimizin listesini veriyor ve üye olmak isteyip istemediğini soruyor. Arzu edenin üye olabilmesi için gerekli Form`u da sunuyoruz.
Programın her iki bölümünde de veri okuyan ve bunu görüntüleyen, yani programın canalıcı noktası, mysql_fetch_row() fonksiyonudur. PHP`nin DML araçlarından olan bu fonksiyonun marifeti, bir veritabanından elde edilen sonucu satır-satır okumasıdır. Nitekim, burada bu fonksiyondan dönen değeri $satir adını verdiğimiz dizi-değişkene yazıyoruz ve sonra printf() bu dizinin elemanlarını sırayla Browser penceresine gönderiyor. (Burada olduğu gibi $satır değişkenin içinde kaç kaç sütun olduğunu bildiğimiz durumlarda printf() fonksiyonunu döngüsüz kullanmak mümkündür. Ancak veritabanının sütun sayısını bilmiyorsak bunu sözgelimi count($satir) yoluyla öğrenip, bu bilgiyle bir for döngüsü kurmak yerinde olur.

Programın iki bölümü arasındaki tek fark, $HTTP_POST_VARS dizi-değişkeninin bir değer tutması halinde (yani ziyaretçi sayfayı açtığında karşısına çıkan Form`u doldurduğu ve gönderdiği zaman) çalışan birinci bölümünde, mysql_query() fonksiyonunun bu kez veritabanı dosyasına ziyaretçinin verdiği bilgileri işlemek üzere farklı bir SQL deyimi içermesidir. Nasıl yazıldığını daha önce ele aldığımız bu fonksiyon "calisanlar" tablosundaki dört alana elimizdeki dört değişkenin değerlerini SQL`in INSERT komutuyla ekliyor.
PHP`nin MySQL ile yapabileceğimiz veritabaynı yönetimi için 20`ye yakın fonksiyonu vardır; MySQL de bu fonksiyonlar yardımıyla çok sayıda iş yapabilir.

Bu konuya son verirken, Form örneğindenden farklı olarak yukarıdaki veritabanı örneğinde ziyaretçinin gireceği bilgilerle ilgili güvenlik önlemleri alınmadığına dikkatinizi çekerim.


Konu: PHP ve MySQL İlişkisi
 
Okunma Sayısı : 213
Eklenme Tarihi : 25 Ocak 2007, Perşembe
SONRAKI BILGI : İstanbul`da ilçeler bile illeri solladı   
Forum Linki:
Aranan Kelime:
 

En Yeni Bilgiler


 PHP De Formlar Get Metodu PHP De Formlar Get Metodu
 PHP De While döngüsü PHP De While döngüsü
 PHP ve Tırnak İşareti PHP ve Tırnak İşareti
 PHP De Parola PHP De Parola
 PHP ve MySQL İlişkisi PHP ve MySQL İlişkisi
 Mysql Veri Türleri Mysql Veri Türleri
 PHP De sql_regcase() PHP De sql_regcase()
 PHP De split() PHP De split()
 PHP De ereg_replace() ve eregi_replace() PHP De ereg_replace() ve eregi_replace()
 PHP De ereg() ve eregi() PHP De ereg() ve eregi()
 PHP De Karakter Grupları PHP De Karakter Grupları
 PHP De Düzenli İfadelerde Özel Karakterler PHP De Düzenli İfadelerde Özel Karakterler
 PHP De Eşleştirme deyimleri ve işaretler PHP De Eşleştirme deyimleri ve işaretler
 PHP De chr() Düzenli İfadeler PHP De chr() Düzenli İfadeler
 PHP De Tarih ve Saat Düzenleme PHP De Tarih ve Saat Düzenleme
 PHP De number_format() Fonksiyonu PHP De number_format() Fonksiyonu
 PHP De printf() ve sprintf() PHP De printf() ve sprintf()
 PHP De strlen() Fonksiyonu PHP De strlen() Fonksiyonu
 PHP De chr() Fonksiyonu PHP De chr() Fonksiyonu
 PHP De trim() Fonksiyonu PHP De trim() Fonksiyonu
 PHP De Alfanümerik Fonksiyonlar PHP De Alfanümerik Fonksiyonlar
 PHP De Örnek Dosya İşlemi PHP De Örnek Dosya İşlemi
 PHP De Dizin Silme PHP De Dizin Silme
 PHP De Dizin Oluşturma PHP De Dizin Oluşturma
 PHP De Dosya Kilitleeme PHP De Dosya Kilitleeme
 PHP De Dosyaya yazma ve ek yapma PHP De Dosyaya yazma ve ek yapma
 PHP De fseek() ile ölçü belirleme PHP De fseek() ile ölçü belirleme
 PHP De Dosya Okuma PHP De Dosya Okuma
 PHP De Fonkisyon Durdurma PHP De Fonkisyon Durdurma
 PHP De Dosya açma PHP De Dosya açma
 PHP De Dosyalar oluşturma ve silme PHP De Dosyalar oluşturma ve silme
 PHP De Dosyaya son erişim tarih PHP De Dosyaya son erişim tarih
 PHP De Dosya Boyutu PHP De Dosya Boyutu
 PHP De is_executable() PHP De is_executable()
 PHP De is_writable() PHP De is_writable()
 PHP De is_readable() PHP De is_readable()
 PHP De is_file() ve is_dir() PHP De is_file() ve is_dir()
 PHP De Dosya Kontrolü PHP De Dosya Kontrolü
 PHP De include ve require PHP De include ve require
 PHP De Dosya Ekleme (include) PHP De Dosya Ekleme (include)
 PHP De Dosya Yükleme PHP De Dosya Yükleme
 PHP De Formlar ve İşlemci PHP De Formlar ve İşlemci
 PHP De Formlar Post Metodu PHP De Formlar Post Metodu
 PHP De URL Kodları PHP De URL Kodları
 PHP De Formlar PHP De Formlar
 PHP De Nesne Oluşturma PHP De Nesne Oluşturma
 PHP De Nesneler PHP De Nesneler
 PHP De Dizileri sıralama PHP De Dizileri sıralama
 PHP De Diziden kesit alma PHP De Diziden kesit alma
 PHP De Dizinin ilk elemanını silme PHP De Dizinin ilk elemanını silme
 PHP De Dizilere değişken ekleme PHP De Dizilere değişken ekleme
 PHP De Dizi Değişkenlerin Düzenlenmesi PHP De Dizi Değişkenlerin Düzenlenmesi
 PHP De Dizi Değişkenleri Kullanma PHP De Dizi Değişkenleri Kullanma
 PHP De Dizi Değişken Oluşturma PHP De Dizi Değişken Oluşturma
 PHP De Dizi Değişkenleri PHP De Dizi Değişkenleri
 PHP De Değişken Kapsamı PHP De Değişken Kapsamı
 PHP De Fonksiyonlara Değer Verme PHP De Fonksiyonlara Değer Verme
 PHP De Fonksiyonlar PHP De Fonksiyonlar
 PHP De Continue PHP De Continue
 PHP De Breack PHP De Breack
 PHP De foreach döngüsü PHP De foreach döngüsü
 PHP De For Döngüsü PHP De For Döngüsü
 PHP DE do..while PHP DE do..while
 PHP ve Switch PHP ve Switch
 PHP ve if - else - ifelse PHP ve if - else - ifelse
 PHP ve Tarih Saat PHP ve Tarih Saat
 PHP ve Sabit Değerler PHP ve Sabit Değerler
 PHP De Azaltma ve Arttırma PHP De Azaltma ve Arttırma
 PHP De Dört İşlem PHP De Dört İşlem
 PHP Deki Dört Yararlı Fonksiyon PHP Deki Dört Yararlı Fonksiyon
 PHP De Boşluklar PHP De Boşluklar
 PHP ve Fonksiyonlar PHP ve Fonksiyonlar
 PHP ve Tür Değiştirme PHP ve Tür Değiştirme
 PHP ve Veri Türleri PHP ve Veri Türleri
 PHP`de Değişkenler PHP`de Değişkenler
 Windows`da MySQL Windows`da MySQL
 Windows`da Apache Windows`da Apache
 PWS 4.0 PWS 4.0
 Browser Yetenek Dosyası Browser Yetenek Dosyası
 IIS 4.0 ve 5.0 IIS 4.0 ve 5.0
 Windows-PWS ve IIS Windows-PWS ve IIS
 Güvenli socket ve Internet Erişimi Katmanı Güvenli socket ve Internet Erişimi Katmanı
 Linux`ta program derlediniz mi? Linux`ta program derlediniz mi?
 Unix - Linux Sistemleri Unix - Linux Sistemleri
 PHP ve Web Sunucusu PHP ve Web Sunucusu
 PHP ve Veritabanı PHP ve Veritabanı
 PHP`ye Giriş PHP`ye Giriş
 MD5 ile Şifreleme MD5 ile Şifreleme
 

 

 

Copyright © 2008 Temha.neT