Post
#1
|
|
|
Administrator serwera Grupa: Przyjaciele php.pl Postów: 909 Pomógł: 0 Dołączył: 12.08.2003 Skąd: /var/www/wroclaw.php Ostrzeżenie: (0%)
|
Dla testów przeniosłem logi serwera Apache do MySQLa...
Niestety zaskoczyła mnie jedna rzecz... Log od 29 marca, g. 02:53 do 31 marca do godziny 23:59 urusł do 42 294 rekordów (6.9 MB) Log dla kwietnia już liczy ponad 70 tys. rekordów... Jak zrobić by zapytania do bazy danych nie trwały po pare (naście) sec. ? Przykładowe zapytanie do bazy [sql:1:627e450951]SELECT `useragent` , count(*) AS count FROM `log_042004` GROUP BY `useragent` ORDER BY count DESC LIMIT 10;[/sql:1:627e450951] Nie wiedziałem jak inaczej zobrazować strukturę bazy, więc wrzucam wam kod ją tworzący... [sql:1:627e450951]CREATE TABLE `log_032004` ( `id` int(11) NOT NULL auto_increment, `d` char(2) default NULL, `H` char(2) default NULL, `i` char(2) default NULL, `s` char(2) default NULL, `method` char(3) NOT NULL default '', `url` text NOT NULL, `query` text NOT NULL, `referer` text NOT NULL, `rhip` varchar(15) NOT NULL default '', `useragent` varchar(255) NOT NULL default '', `https` char(2) NOT NULL default '', PRIMARY KEY (`id`) ) TYPE=MyISAM AUTO_INCREMENT=42301;[/sql:1:627e450951] Już zrobiłem, by każdy miesiąc był zapisywany do kolejnej tabeli, ale perspektywa zbierania 11500 kolejnych rekordów statystyk nie rysuje się kolorowo... Jak zoptymalizować tą bazę i/lub zapytania by to chodziło szybciej (IMG:http://forum.php.pl/style_emoticons/default/questionmark.gif) |
|
|
|
![]() |
Post
#2
|
|
|
Grupa: Zarejestrowani Postów: 207 Pomógł: 0 Dołączył: 7.09.2003 Ostrzeżenie: (0%)
|
tworzenie indexow dla najbardziej uzywanych koloumn??
nie tworz dla tych co nie sa uzywane (IMG:http://forum.php.pl/style_emoticons/default/smile.gif) . nie uzywaj pol typu txt,blob i varchar. zawsze przypisuj tam gdzie yto mozliwe wartosci domyslnych, stsuj stale polaczenia z baza.. [url=http://www.mysql.com/]MYSQL.COM Tam szukaj a nie zbladzisz U2DATE 1 jesli ty zarzadzasz mysql'em to stosuj uproszczony system przywilejow - kilka moli-sec ^^ |
|
|
|
Bakus Optymalizacja bazy danych [nie chodzi OPTIMIZE] 11.04.2004, 01:54:39
DeyV 1. dlaczego data w 4 polach, zamiast w 1? Pola dat... 11.04.2004, 08:42:49
Bakus Pomysł z kolejnymi tabelami przyszedł po zobaczeni... 11.04.2004, 15:34:47
DeyV no ale ja nie widzę problemu.
Przeciez w ten spos... 11.04.2004, 15:42:17 ![]() ![]() |
|
Aktualny czas: 27.12.2025 - 06:09 |