v2.5.2
Giriş yap

Sql Sorgum Çok Yavaş Çalışıyor

zfactor
1,164 defa görüntülendi

Merhabalar, klasik asp ile otel rezervasyon takip sistemi hazırlıyorum, aylık olarak hangi odalarda kim misafir olacak takibini yaptırıyorum.
0,02,03 yazan yerler oda numaralarım.

Alttaki kodu kullandığımda 17-18 saniye'de sorgu sonuçlanıyor.

<%set oda=baglanti.execute("select * from oda order by id asc")
do while not oda.eof
set rezervasyon=baglanti.execute("select id,odaid,adsoyad,giristarihi,cikistarihi from rezervasyon where odaid='"&oda("id")&"' and (giristarihi<='"&gun&"' and cikistarihi>'"&gun&"') limit 1")%>
<%if rezervasyon.eof then%><td>boş</td><%else%><td style="background:#ddd; font-size:12px;"><%=rezervasyon("adsoyad")%></td><%end if%>
<%oda.movenext:loop%>

Bu kodumu çalıştırdığım zaman aşağıdaki gibi istediğim sonucu alıyorum, fakat çok yavaş çalışıyor belirttiğim gibi.

Alttaki kodu çalıştırdığım zaman ise gayet hızlı sonuç alıyorum, fakat şöyle bir sıkıntı var, bu kodda sadece eşleşen veriler geldiği için, eğer kayıt yoksa boş durumda olarak gösteremiyorum ve dolayısıyla tabloda kaymalar oluyor.

<%set rezervasyon=baglanti.execute("select odam.id,rezervasyonum.odaid,rezervasyonum.adsoyad ADOSOYAD,rezervasyonum.giristarihi,rezervasyonum.cikistarihi from rezervasyon as rezervasyonum inner join oda as odam on odam.id=rezervasyonum.odaid where rezervasyonum.giristarihi<='"&gun&"' and rezervasyonum.cikistarihi>'"&gun&"'")
do while not rezervasyon.eof%>
<%if rezervasyon.eof then%><td></td><%else%><td style="background:#ddd; font-size:12px;"><%=rezervasyon("ADOSOYAD")%></td><%end if%>
<%rezervasyon.movenext:loop%>

Tüm sayfadaki kodun tamamını altta belirttim.

<table>
<tr>
<td>Tarih</td>
<%set oda=baglanti.execute("select * from oda order by id asc")
do while not oda.eof%>
<td><b><%=oda("baslik")%></b></td>
<%oda.movenext:loop%>
</tr>
<%AydakiTumGunler="2021-04-01,2021-04-02,2021-04-03,2021-04-04,2021-04-05,2021-04-06,2021-04-07,2021-04-08,2021-04-09,2021-04-10,2021-04-11,2021-04-12"
gunler = split(AydakiTumGunler, ",")
for i=0 to ubound(gunler)
noktaligun=gunler(i)
noktaligun=tarihnoktaliformat(noktaligun)
gun=gunler(i)%> 
<tr>
<td><b><%=noktaligun%></b></td>
<%set rezervasyon=baglanti.execute("select odam.id,rezervasyonum.odaid,rezervasyonum.adsoyad ADIM,rezervasyonum.giristarihi,rezervasyonum.cikistarihi from rezervasyon as rezervasyonum inner join oda as odam on odam.id=rezervasyonum.odaid where rezervasyonum.giristarihi<='"&gun&"' and rezervasyonum.cikistarihi>'"&gun&"'")
do while not rezervasyon.eof%>
<%if rezervasyon.eof then%><td><%bos=bos+1%>x</td><%else%><td style="background:#ddd; font-size:12px;"><%=rezervasyon("ADIM")%><%dolu=dolu+1%></td><%end if%>
<%rezervasyon.movenext:loop%>
</tr>
<%next%>
</table>
aydinkeskin
1143 gün önce

söyle söylim bugun bir hdd ye xampp kurdum normalde jilet gibi çlışan site 15 sn de neymiş dedirdetecek gibi 1 dk bile sürdüğü oluyor
sunucuda 1-2 sn aralığında ise windows hostinglerin sorunu malesef
aldığın hosting çok önemli

basit bir örnek daha vereyim alakasız sen anla

pagespped değeri bi firmada 84 çıkıyor diğer firmada 97 çıkıyor bu mekanik hızla alakası yok tabiki
ama windows hostinglere eski rağmen günümüzde pek yok diye düşünüyorum
php de de olabiliyor localde 0,6 sn de açılan 15 tane veri hostingde 1.21 sn açılıyor başka bir hostingde 0,4 sn de çalışıyor
kodsal olarak yapabileceklerin tabiki var ama
bu sayfanın açılış hızı sadece kodla alakalı değil

dışardan çağırdığın css js vb içeriklerde bunu yavaşlatıyor olabilir.

ve sana tavsiyem bırak asp yi artık :) php ye asp bilgin ile 1 haftalık hızlandırılmış kurs ile çok rahat ça geçersin