Nie jesteś zalogowany.
Jeśli nie posiadasz konta, zarejestruj je już teraz! Pozwoli Ci ono w pełni korzystać z naszego serwisu. Spamerom dziękujemy!

Ogłoszenie

Prosimy o pomoc dla małej Julki — przekaż 1% podatku na Fundacji Dzieciom zdazyć z Pomocą.
Więcej informacji na dug.net.pl/pomagamy/.

#1  2014-02-10 10:06:28

  Huk - Smoleńsk BULWA!

Huk
Smoleńsk BULWA!
Zarejestrowany: 2006-11-08

SQL - jaka będzie wydajność takiego zapytania

Założenie:

Mam bazę SQL z prostą tabelą (nazwijmy ją "Tab1"):

Kod:

ID
Nazwa
FK_KategoriaID

oraz tabelę kategorii (nazwijmy ją "TabKat"):

Kod:

ID
Nazwa

Zakładając że w pierwszej tabeli będę miał np. milion wierszy z kategorią "X" oraz jeden z kategorią "Y", oraz będę miał index założony na ID'ku tabeli ile potrwa zapytanie w stylu:

Kod:

select * from Tab1 as T1
where Tab1.FK_KategoriaID = JakieśIdKategorii

? Czy SQL jest na tyle mądry że jakoś grupuje sobie wewnętrznie po kluczach obcych i wyszuka to w milisekundę, czy też będzie leciał wszystkie wiersze po kolei?

Pozdrawiam.

Offline

 

#2  2014-02-10 10:16:07

  hello_world - Członek DUG

hello_world
Członek DUG
Skąd: Rymanów Zdrój
Zarejestrowany: 2010-06-03
Serwis

Re: SQL - jaka będzie wydajność takiego zapytania

Powinno pójść szybko. Nie wiem czy w milisekundach ale w kilku sekundach powinno dać rade. Jak masz wypaśną maszynę to da radę. Nie jest to skomplikowane zapytanie.

Offline

 

#3  2014-02-10 12:10:11

  Huk - Smoleńsk BULWA!

Huk
Smoleńsk BULWA!
Zarejestrowany: 2006-11-08

Re: SQL - jaka będzie wydajność takiego zapytania

@hello_world:

Hmmm może troszkę źle zadałem pytanie - wiem że nowy komp przetrwa takie coś w sekundę czy dwie - zastanawiam się tylko czy da się jakoś tak zoptymalizować zapytanie żeby lockup time był stał (lub prawie stały) jeżeli z miliona wierszy potrzebuję dwóch czy trzech. Zdaje się że SQL standardowo zakłada indeksy na kluczach obcych stąd pytanie czy będzie lecieć po kolei czy jakoś wydajniej. Bardziej chyba do osób znających niskopoziomowe optymalizacje na serwerach SQL ;]

Offline

 

#4  2014-02-10 13:12:06

  mAg - Członek DUG

mAg
Członek DUG
Skąd: Mrągowo
Zarejestrowany: 2004-12-23
Serwis

Re: SQL - jaka będzie wydajność takiego zapytania

a jaki to silnik... powyżej określonej liczby werszy to właśnie od niego będzie zależało szybkość działania.


.:: Linux connecting people :D ::.  Linux Registered User #358097 Debian GNU/Linux

https://linuxcounter.net/cert/358097.png

Offline

 

#5  2014-02-10 14:34:17

  Huk - Smoleńsk BULWA!

Huk
Smoleńsk BULWA!
Zarejestrowany: 2006-11-08

Re: SQL - jaka będzie wydajność takiego zapytania

Powiedzmy że M$ SQL Serwer - ale wydaje mi się (może błędnie) że taka optymalizacja powinna się odbywać w każdym popularnym serwerze...

Offline

 

#6  2014-02-10 15:04:09

  Piotr3ks - Też człowiek :-)

Piotr3ks
Też człowiek :-)
Skąd: Białystok
Zarejestrowany: 2007-06-24

Re: SQL - jaka będzie wydajność takiego zapytania

No to może indeksowanie tabel?
http://di.com.pl/porady/25700,0,Porada_MySQL_a_popr … plikacji.html

Najlepiej jest sobie poeksperymentować.Stworzyć fikcyjną bazę danych i bawić się na niej.

Offline

 

Stopka forum

Powered by PunBB
© Copyright 2002–2005 Rickard Andersson
To nie jest tylko forum, to nasza mała ojczyzna ;-)