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

Web Tasarım İnternet sitesi ile ilgili kodlar, kaynaklar, ipuçları, uygulamalar ve diğer herşey.

Cevap
 
Konu Araçları
Eski 23.05.2007   #1 (permalink)
ultrAslan
 
Katılma Tarihi: Mar 2007
Nereden: izmir
Mesajlar: 124
Varsayılan ASP Veritabanı İşlemleri

Veritabanı muhabbetimiz tam gaz devam ediyor. Bu yazıda bir çok veritabanı operasyonunu birlikte göreceğiz. Kayıt ekleme, silme, güncelleme gibi. Kullanacağımız veritabanı dosyası burada(8,15 kb). Bu dosya C:\inetpub\wwwroot\db konumunda olsun. Sıra geldi script dosyalarımıza.

KAYITLAR.ASP

Öncelikle kayıtları listeleyeceğimiz bir arabirim inşa ettik. kayitlar.asp ye göz atalım. Bu ve diğer ASP dosyaları C:\inetpub\wwwroot\ konumunda olsun.
Kod1. kayitlar.asp

Kod:
<% 
Veri_yolu = Server.MapPath("db/kisiler.mdb") 
Bcumle = "DRIVER={Microsoft Access Driver (*.mdb)};DBQ=" & Veri_yolu 
Set bag = Server.Createobject("ADODB.Connection") 
bag.Open (Bcumle) 
Set kset = bag.execute("SELECT * FROM kisiler") 
%> 
<% i=1 %> 
<p><a href="kayit_yeni.asp">Yeni Kayıt</a></p> 
<table border=1> 
<tr> 
<th>#</th> 
<th>Ad</th> 
<th colspan=2>Eylemler</th> 
</tr> 
<% Do While Not kset.eof %> 
<tr><td><%= i %></td> 
<td><%= kset("ad") %></td> 
<td><a href="kayit_duzenle.asp?id=<%= kset("id") %>">düzenle</a></td> 
<td><a href="kayit_sil.asp?id=<%= kset("id") %>">sil</a></td></tr> 
<% kset.movenext %> 
<% i = i + 1 %> 
<% Loop %> 
</table> 
<% 
kset.Close 
Set kset = Nothing 
bag.Close 
Set bag = Nothing 
%> 
Bu script, basit bir şekilde /db alt dizinindeki kisiler.mdb ile bağlantı kuruyor. kisiler tablosundan aldığı tüm kayıtların "ad" alanındaki değerlerini yazdırıyor. Ve de her bir kayıt için düzenleme ve silme linkleri oluşturuyor. Linkler oluşturulurken sorgu stringi içinde eylemi gerçekleştirecek script dosyasına "id" anahtarıyla kaydın "id" alanındaki değeri gönderiliyor. Tabi bunlar kayıtseti sonunda duracak bir döngü içerisinde yapılıyor. Veriler tablo hücrelerine döngüyle döküldüğüne de dikkat ediniz.

KAYIT_DUZENLE.ASP ve KAYIT_GUNCELLE.ASP

Kayıtların listelendiği kayitlar.asp de her kaydın yanında bir düzenle bağlantısı var. Bu bağlantı ile duzenle.asp dosyasına işaret ediliyor. Bir de sorgu cümlesi konuluyor yanına: "duzenle.asp?id=XX" Buradaki XX yerine geçerli kaydın id alanındaki değeri yazılıyor. Şimdi kayıt_duzenle.asp ye bakalım.
Kod2. kayit_duzenle.asp

Kod:
<% 
id = Request.Querystring("id") 
If Not Isnumeric(id) Or Len(id)=0 Then 
mesaj "Yanlış Sorgu Cümlesi" 
End If 
'----------------------------------------------------------------------------------- 
Veri_yolu = Server.MapPath("db/kisiler.mdb") 
Bcumle = "DRIVER={Microsoft Access Driver (*.mdb)};DBQ=" & Veri_yolu 
Set bag = Server.Createobject("ADODB.Connection") 
bag.Open (Bcumle) 
Set kset = bag.execute("SELECT * FROM kisiler where id =" & id) 
If kset.eof Then 
mesaj "Olmayan Kayıt İstendi" 
End If 
%> 

Kod:
<% 
id = Request.Querystring("id") 
If Not Isnumeric(id) Or Len(id)=0 Then 
mesaj "Yanlış Sorgu Cümlesi" 
End If 
'----------------------------------------------------------------------------------- 
Veri_yolu = Server.MapPath("db/kisiler.mdb") 
Bcumle = "DRIVER={Microsoft Access Driver (*.mdb)};DBQ=" & Veri_yolu 
Set bag = Server.Createobject("ADODB.Connection") 
bag.Open (Bcumle) 
Set kset = bag.execute("SELECT * FROM kisiler where id =" & id) 
If kset.eof Then 
mesaj "Olmayan Kayıt İstendi" 
End If 
%> 
Kod:
<% 
kset.Close 
Set kset = Nothing 
bag.Close 
Set bag = Nothing 
%> 
<%'--------------------------%> 
<% Sub mesaj(msg) %> 
<p><%= msg %></p> 
<% response.end %> 
<% End Sub %> 
<%'--------------------------%> 
Aslında bu scriptin de öncekinden pek farkı yok. sadece sorgu cümlesinden "id" anahtarındaki değeri alıyor. Ve bu id değerini kullanarak tablodan tek kayıt seçiyor. ("SELECT * FROM kisiler where id =" & id). Seçtiği kayda ait değerleri ise form input alanlarına döküyor. Formun action özelliğine ise kayit_guncelle.asp yazılmış. Güncelleme işini bu dosyaya havale ediyoruz. 
Kod3. kayit_guncelle.asp 
<% 
ad = Request.Form("ad") 
id = Request.Form("id") 
telefon = Request.Form("telefon") 
dgunu = Request.Form("dgunu") 
icq = Request.Form("icq") 
email = Request.Form("email") 
adres= Request.Form("adres") 
'----------------------------------------------------------------------------------- 
Veri_yolu = Server.MapPath("db/kisiler.mdb") 
Bcumle = "DRIVER={Microsoft Access Driver (*.mdb)};DBQ=" & Veri_yolu 
Set bag = Server.Createobject("ADODB.Connection") 
bag.Open (Bcumle) 
Set kset = Server.Createobject("ADODB.Recordset") 
sql = "SELECT * FROM kisiler WHERE id = " & id 
kset.open sql, bag, 1, 3 
kset("ad") = ad 
kset("telefon") = telefon 
kset("email") = email 
kset("adres") = adres 
kset("icq") = icq 
kset("dogum_gunu") = dgunu 
kset.update 
kset.Close 
Set kset = Nothing 
bag.Close 
Set bag = Nothing 
Response.Write "<p>Kayıt Yapıldı.. Başka bir arzunuz? " 
Response.Write "<p><a href=""kayitlar.asp"">Kayıtlar</a>" 
%> 
KAYIT_YENI.ASP

kayitlar.asp de Yeni Kayıt linkinde işaret edilen kayit_yeni.asp... Yaptığı iş şu. Veritabanına bağlanıp ilgili tablodan oluşturduğu kayıt seti içine yeni bir kayıt ekliyor. Kayıtsetini güncelliyor, "id" alanındaki değeri bir değişkende saklıyor. nesneleri kapatıyor. Ve de kayit_duzenle.asp dosyasına "id" anahtarıyla yeni eklenen kaydın "id" alanındaki değeri gönderiyor. Yani bu sayfa sadece işlem yapıyor. Kullanıcıya gözükmeden işlemi tamamlayıp düzenleme sayfasına yöneliyor.
Kod4. kayit_yeni.asp

Kod:
response.buffer=true 
Veri_yolu = Server.MapPath("db/kisiler.mdb") 
Bcumle = "DRIVER={Microsoft Access Driver (*.mdb)};DBQ=" & Veri_yolu 
Set bag = Server.Createobject("ADODB.Connection") 
bag.Open (Bcumle) 
Set kset = Server.Createobject("ADODB.Recordset") 
sql = "SELECT * FROM kisiler" 
kset.open sql, bag, 1, 3 
kset.addnew 
kset.update 
id = kset("id") 
kset.Close 
Set kset = Nothing 
bag.Close 
Set bag = Nothing 
Response.Redirect "kayit_duzenle.asp?id=" & id 
%> 


KAYIT_SIL.ASP

Sorgu cümlesindeki "id" anahtarından alınan id değeri kullanılarak şu SQL ifadesi oluşturuluyor.
DELETE FROM kisiler WHERE id = " & id . Ve bu ifade bağlantı tarafından yürütülüyor (execute). Sonuçta id si alınan kayıt tablodan silinmiş oluyor. Kullanıcı da geldiği sayafaya yönleniyor.
Kod5. kayit_sil.asp
Kod:
<% 
response.buffer = True 
id = Request.Querystring("id") 
'----------------------------------------------------------------------------------- 
Veri_yolu = Server.MapPath("db/kisiler.mdb") 
Bcumle = "DRIVER={Microsoft Access Driver (*.mdb)};DBQ=" & Veri_yolu 
Set bag = Server.Createobject("ADODB.Connection") 
bag.Open (Bcumle) 
sql = "DELETE FROM kisiler WHERE id = " & id 
Set kset = bag.execute(sql) 
Set kset = Nothing 
bag.Close 
Set bag = Nothing 
Response.Redirect (Request.ServerVariables("HTTP_REFERER")) 
%> 
__________________
İşi olmayan giremez çünkü içerde yeterince işsiz var...
maChaRa Şuanda Forumda Değil   Alıntı yaparak cevapla
Bu mesaj için maChaRa kişisine teşekkür edenler:
fatma8580 (24.05.2007)
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
C++ ile Dosyalama İşlemleri.... staticiation Programlama & Geliştiriciler için 4 11.04.2008 21:21
ADO ve ADOX kullanarak Access veritabanı oluşturma... staticiation Programlama & Geliştiriciler için 0 19.06.2007 01:22
PHP ve Veritabanı Bağlantıları... staticiation Web Geliştirme Dilleri 3 09.06.2007 14:02
Php de Değişken İşlemleri... staticiation Web Geliştirme Dilleri 0 08.06.2007 16:04
ASP String İşlemleri maChaRa Web Tasarım 0 23.05.2007 09:28


Şu anki forum saati: 19:24.


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