[Linux-programlama] Re: MySQL: sorgu analizi

---------

[Linux-programlama] Re: MySQL: sorgu analizi

From: Ismail ASCI <ismail.asci_at_gmail.com>
Date: Sat, 5 Apr 2008 22:40:17 +0300
Message-ID: <28814fb60804051240g5241fdla5e8b6e574d2371e@mail.gmail.com>

tekrar merhabalar,
gonderdiginiz tablo yapisinda mysql olusturdugunuz index'leri
kullanmayacaktir. yani onlari olusturmus olmanizin bir faydasi yok.
basitce f ve e alanlari uzerinde key yeni (f, e) seklinde bir index
olusturmaniz oldukca faydali olacaktir diye dusunuyorum.
bu asamadan sonra
1. sorgunuzda order by random() yerine
select a, b, c, random() as x ......order by x seklinde deneyebilir misiniz?
2. ve 3. sorgular da ise benim aklima gelen pek birsey yok acikcasi esit
degil ve not null pek hos durmuyorlar orada :)

kolay gelsin.

2008/4/4 Anıl KARADAĞ <anil.karadag_at_gmail.com>:

> harflendirmeleri duzenledim
>
> tablo1:
>
> 'a' mediumint(11) NOT NULL auto_increment,
> 'b' text
> 'c' text
> 'd' text
> 'e' datetime,
> 'f' varchar(20) ,
> 'g' varchar(20) ,
> PRIMARY KEY ('a'),
> KEY 'e' USING BTREE ('e'),
> KEY 'b' ('b'(50),'c'(250))
> ) ENGINE=MyISAM
>
> SELECT a,b,c FROM tablo1 WHERE f='x' AND
> > cast(e as date)= '".$date."' ORDER BY rand() LIMIT 10
> >
> > 2-SELECT COUNT(*) FROM tablo1 WHERE f='x' and
> > cast(e as date)= '".$date."' and (c != '' or c is not null)
> >
> > 3-SELECT MAX(a) FROM tablo WHERE f= '".$cat." ' and
> > cast(e as date)= '".$date."' and (c != '' or c is not null)
>
> Sorgu cıktıları ile ilgili ne gibi bir acıklama koyabilirim anlayamadım
> tam olarak?
>
> Cum, 2008-04-04 tarihinde 23:39 +0300 saatinde, Ismail ASCI yazdı:
> > Merhaba,
> > index'ler hangi alanlarda tanimlilar?
> > cast(b as date) kullanmanizin nedeni nedir?
> > ayrica ORDER BY rand() pek efektif sonuclar doguracak gibi gorunmuyor.
> > tablonuzun yapisini ve bu uc sorgunun explain ciktisini
> > gonderebilirseniz daha fazla yardimci olmaya calisabilirim.
> > kolay gelsin..
> >
> > 2008/4/4 Anıl KARADAĞ <anil.karadag_at_gmail.com>:
> > Herkese iyi aksamlar MySQL kullanan ve tablolarında 300.000
> > satir ve
> > uzeri veriye sahip ve veritabanindan sorumlu uyelerimizin
> > dikkatine
> >
> > Suan 350.000 satır veri iceren bir tablom bulunmaktadır. 1
> > primary key
> > ve 2 tane normal index içermekte. Arama yaptigim diger bircok
> > kolonda
> > index bulunmuyor.
> >
> > 1-SELECT a,b,c FROM tablo1 WHERE a='x' AND
> > cast(b as date)= '".$date."' ORDER BY rand() LIMIT 10
> >
> > 2-SELECT COUNT(*) FROM tablo1 WHERE a='x' and
> > cast(b as date)= '".$date."' and (c != '' or c is not null)
> >
> > 3-SELECT MAX(e) FROM tablo WHERE a= '".$cat." ' and
> > cast(b as date)= '".$date."' and (c != '' or c is not null)
> >
> > ve benzeri sorgulari calistirdigim php sayfasi cok gec
> > yukleniyor. Bu
> > duruma nasıl cozum bulabilirim. Belirtmen gereken bir nokta
> > tablonun
> > dinamik olusudur. Gunluk ortalama bir sayida kayit
> > girilmektedir.
> >
> > Kayit girilirken db uzerinde cesitli sorgular yapilmaktadir.
> > Kisacasi
> > sistemde veri girisi sorgusu ve goruntuleme sorguları ayni
> > zaman
> > diliminde gerceklesmektedir gunun belirli bir diliminde.
> >
> > Cluster konusuna bakiyorum. Onerilerinizi bekliyorum.
> >
> > _______________________________________________
> > Linux-programlama mailing list
> > Linux-programlama_at_liste.linux.org.tr
> > http://liste.linux.org.tr/mailman/listinfo/linux-programlama
> >
> >
> >
> > --
> > Ismail ASCI
> > Pozitim Technology
> > www.pozitim.com
> >
> > -----BEGIN PGP PUBLIC KEY BLOCK-----
> > Version: GnuPG v1.4.2.2 (GNU/Linux)
> >
> > iFQEIBECABQFAkRIDJMNHQBiYWNrdXAgY29weQAKCRBgYvyi4RxNdcnIAJ9vweb8
> > vUH9m3a2aQHyAfeo0oJtlACfQiqcbHvdBtrxylRh42G2xea7gFM=
> > =Xy4T
> > -----END PGP PUBLIC KEY BLOCK-----
> > _______________________________________________
> > Linux-programlama mailing list
> > Linux-programlama_at_liste.linux.org.tr
> > http://liste.linux.org.tr/mailman/listinfo/linux-programlama
>
> _______________________________________________
> Linux-programlama mailing list
> Linux-programlama_at_liste.linux.org.tr
> http://liste.linux.org.tr/mailman/listinfo/linux-programlama
>

-- 
Ismail ASCI
Pozitim Technology
www.pozitim.com
-----BEGIN PGP PUBLIC KEY BLOCK-----
Version: GnuPG v1.4.2.2 (GNU/Linux)
iFQEIBECABQFAkRIDJMNHQBiYWNrdXAgY29weQAKCRBgYvyi4RxNdcnIAJ9vweb8
vUH9m3a2aQHyAfeo0oJtlACfQiqcbHvdBtrxylRh42G2xea7gFM=
=Xy4T
-----END PGP PUBLIC KEY BLOCK-----

_______________________________________________
Linux-programlama mailing list
Linux-programlama_at_liste.linux.org.tr
http://liste.linux.org.tr/mailman/listinfo/linux-programlama
Received on Sat 05 Apr 2008 - 21:55:49 EEST

---------

Bu arsiv hypermail 2.2.0 tarafindan uretilmistir.