Geri Dön   Forum Ti > Programlama Dilleri ve İnternet > Web Geliştirme Dilleri
Üye Ol Üye Listesi Takvim Forumları Okundu İşaretle

Web Geliştirme Dilleri İnternet sitesi geliştirme için kullanılan araçlar ve programlama dilleri... ASP & ASP.NET & PHP & CSS & HTML & SQL & Java Script

Cevap
 
Konu Araçları
Eski 09.06.2007   #1 (permalink)
 
Katılma Tarihi: Şub 2006
Nereden: Bursa/es-es
Yaş: 23
Mesajlar: 1,780
Varsayılan Veritabanı Tablosundan Çekilen Verilerin HTML Sayfasında Numaralandırılarak Gör...

MySQL veritabani tablolarinda kullanilan ve bir tablo alaninin
AUTO_INCREMENT olarak tanimlanmasi sonucu her satirdaki verinin kolayca
indexlenebildigi (MySQL Primary Key olarak tanimalanan alani ayni
zamanda indexler.) ve birbirinden essiz olarak ayrilabildigi alanlari tutup
da verilerinizi web uzerinde gosterirken numaralandirmak icin kullanmayiniz.


Unutmayin tablodaki her alan PRIMARY KEY (birincil anahtar) olarak
tanimlanabildigi gibi bu tablo alanlarinin birlesimi olarak da PRIMARY KEY
tanimlanabilir.Sonucta bir veriyi sildiginizde artik o alana ayrilmis olan
sayisal deger tabloda bir asimetriklik yaratir.Ornegin verileriniz 1,2,3,4,5...
olarak siralaniyor ise dogal olarak siz 4 degerine sahip veriyi sildiginizde
artik bu sayisal siralama da bozulur.



Bu durumda direkt olarak bu alandan aldiginiz verileri,asagidan yukari dogru
siralama yaparken HTML sayfasinda index olarak kullanirsaniz,sonucta ilk
baslarda basarili olsaniz dahi sonradan yeni veriler eklendiginde veya
silindiginde sizde bu isten zararli cikarsiniz...



Bu ornegimizde sizlere bir dongu icinde verilerinizi nasil kolayca
numaralandirabileceginizi gosterecegiz.Boylece veritabanindaki bir alani alip
gostermek yerine dongu sayacini siralama araci olarak kullanacagiz.



Veritabani tablosundaki 1,2,3,4,5,7,9,12 gibi degerler artik bizim icin herhangi
bir sorun teskil etmeyecek.Hem zaten o alanlar verileri kullaniciya gosterirken
siralama araci olarak degil,verileri tanimlamak icin birer essiz anahtar olmasi
amaciyla kullaniliyorlar...



Simdi elimizde bir veritabani tablosu var ve bizde bu tablodan yapilan arama
sonuclarini ekranda listeleyecegiz.Bu listeleme ornegin 8 kayit arama sonucunda
bulunmus ise 1 den 8'e kadar yapilacak.Ornegimizde bir kitapcidaki veritabaninda
ornegin degisik kategorilerdeki kitaplari verdigimiz anahtar kelimelerle
aradigimizi dusunelim.Kullanici bir cek-birak menuden kategoriyi seciyor ve
altindaki kucuk arama kutusuna ise istedigi anahtar kelimeyi yaziyor.




Evet bu basit sayfayi gordugunuze gore simdi bu sayfadan alinan verilerin MySQL
veritabaninda, PHP kullanilarak nasil uygulandigina bakalim.Hersey belirli bir
sira ile ve normal sekilde gerceklestiriliyor.Tek fark HTML ciktisi alinirken
buldugumuz arama sonucuna gore tum kayitlari 1 den baslayarak numaralandirarak
listeliyoruz...



Sozu fazla uzatmadan koda gecelim :











<html>
<head>
<title>Arama Sonuclari</title>
<body>
<h1> .::: Arama Sonuclari :::.</h1>
<?php
trim ($aranan_kelime); //Kelimenin saginda ve solundaki beyaz bosluklari sil



if (!$aranan_kategori || !$aranan_kelime)
{
echo "Arama ile ilgili tum detaylari girmediniz";
exit;
}



$aranan_kelime = addslashes($aranan_kelime); //Gerekli olan yerlere slash ekle
$aranan_kategori = addslashes($aranan_kategori);



$db = mysql_pconnect("localhost","turkphp_user","******* ");
if (!$db)
{
echo "Veritabani ile ilgili bir problem var";
exit;
}



mysql_select_db("turkphp_veritabani");



$sorgu = "SELECT * FROM kitaplar";
$sorgu .= " WHERE ". $aranan_kategori ." LIKE '%". $aranan_kelime ."%'";



$sonuc = mysql_query ($sorgu);



$sonuc_sayisi = mysql_num_rows($sonuc);



echo "<p>Bulunan Sonuc Sayisi : ". $sonuc_sayisi ."</p>";



for ($i=0; $i<$sonuc_sayisi;$i++)
{
$satir = mysql_fetch_array($sonuc);
echo "<p><strong>". ($i+1) ."Baslik:";
echo htmlspecialchars(stripslashes($satir["baslik"]));



echo "</strong><br>Yazar:";
echo htmlspecialchars(stripslashes($satir["yazar"]));



echo "<br>ISBN:";
echo htmlspecialchars(stripslashes($satir["isbn"]));



echo "<br>Fiyat:";
echo htmlspecialchars(stripslashes($satir["fiyat"]));
echo "</p>";



}
?>
</body>
</html>
staticiation Şuanda Forumda Değil   Alıntı yaparak cevapla
Cevap


Şu Anda Konuyu İnceleyen Aktif Kullanıcılar: 1 (0 üye ve 1 misafir)
 
Konu Araçları


Benzer Konular
Konu Konuyu Başlatan Forum Cevaplar Son Mesaj
ogame sayfasında muzik Myst3rious Ogame 5 04.02.2008 16:05
Excel de Verilerin Analizi... staticiation Programlama & Geliştiriciler için 0 06.06.2007 14:30
Excel de Verilerin Görsel Sunuluşu... staticiation Programlama & Geliştiriciler için 0 06.06.2007 14:29
Kabe'nin Çekilen İlk Fotoğrafı The Answer İslamiyet 3 27.01.2007 21:31
Web Sayfasında Müzik Çalma SpeeDy Web Tasarım 14 05.12.2006 21:31


Şu anki forum saati: 23:02.


cnt hizmet sağlayan firma
ForumTi.com'un yapımı ve yayınlanması CNT'ye aittir.
Sitedeki içerikleri foruma ücretsiz şekilde üye olabilen ziyaretçiler oluşturur. Bu içeriklerin sorumluluğu yazana aittir.
Eğer yasak ve aykırı içerik tespit edilirse site yöneticilerine bu konular bildirilir ve kaldırılır. Site yönetimi haberdar edildiğinde sonuç alınamaz ise servis sağlayıcı CNT'ye bildiride bulunabilirsiniz.
vBulletin® v3.7.2, Copyright ©2000-2008, Jelsoft Enterprises Ltd. Search Engine Friendly URLs by vBSEO 3.2.0

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265