Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> shoutbox, ogromnie ID
koskitos
post
Post #1





Grupa: Zarejestrowani
Postów: 149
Pomógł: 0
Dołączył: 18.04.2004
Skąd: Z nikąd

Ostrzeżenie: (30%)
XX---


chce zrobic shputbox. Wiem chyba jak sie zabrac. Dodawanie, wczytywanie - no problem.
Ale mam dwa pytania:
1. W miarę dodawania wpisów ID będzie rosło, a stare wpisy usuwane. Jak sobie z tym poradzić? Myślałem, aby nie robić pola ID...
2. Jak usunąć tabeli wszystkie wpisy pozostawiając 10 najnowszych. Chcę użyć jednego zapytania...


--------------------
kOskiToS :D
Go to the top of the page
+Quote Post
scanner
post
Post #2





Grupa: Zarząd
Postów: 3 503
Pomógł: 28
Dołączył: 17.10.2002
Skąd: Wrocław




a. po co usuwac stare wpisy?
b. ID może być naprawdę duże i niczemu to nie przeszkadza

Pozatym, pole ID zawsze jest potrzebne jesli chcesz w jakiś sposób administrowac contentem. Jak inaczej odnajdziesz okreslony rekord wśród innych?


--------------------
scanner.info
Warto pamiętać: KISS, DRY
Go to the top of the page
+Quote Post
koskitos
post
Post #3





Grupa: Zarejestrowani
Postów: 149
Pomógł: 0
Dołączył: 18.04.2004
Skąd: Z nikąd

Ostrzeżenie: (30%)
XX---


Mam swoje powody.
Wpisów będzie napraaawde duużo. Z tego winkają moje pytania.
Muszę usuwać stare wpisy - usune te z przed tygodnia - poradze sobie,
ale ID jest problemem.
Nie da się ustawić, aby ID było dodawane od najmniejszych liczb?


--------------------
kOskiToS :D
Go to the top of the page
+Quote Post
sf
post
Post #4





Grupa: Zarejestrowani
Postów: 1 597
Pomógł: 30
Dołączył: 19.02.2003
Skąd: Tychy

Ostrzeżenie: (0%)
-----


Ile to jest duzo? Ile na dzien? Z moich wyliczen wynika, ze zwykly serial z postgresa wystarczy Ci na 68 lat jesli jeden wpis bedzie co sekunde.


--------------------
Zapraszam na mój php blog, tworzenie stron.
Go to the top of the page
+Quote Post
Termit_
post
Post #5





Grupa: Zarejestrowani
Postów: 44
Pomógł: 0
Dołączył: 11.06.2005
Skąd: Gostyń

Ostrzeżenie: (0%)
-----


W MySQL zaś, ustawiając typ kolumny z ID na BIGINT UNSIGNED, otrzymujesz maksymalną wartość wynoszącą 18446744073709551615. Chyba starczy na jakiś czas? smile.gif.

Zresztą, chyba INT też by starczył.

http://dev.mysql.com/doc/refman/5.0/en/numeric-types.html


--------------------
@nospor: trzymajcie się. Wszystko będzie dobrze!
Go to the top of the page
+Quote Post
koskitos
post
Post #6





Grupa: Zarejestrowani
Postów: 149
Pomógł: 0
Dołączył: 18.04.2004
Skąd: Z nikąd

Ostrzeżenie: (30%)
XX---


OK, a jeszcze jedno. smile.gif
Jak usunąć za pomocą jednego zapytania najstarsze wpisy z tabeli, pozostawiająć jedynie 30 najnowszych.


--------------------
kOskiToS :D
Go to the top of the page
+Quote Post
sf
post
Post #7





Grupa: Zarejestrowani
Postów: 1 597
Pomógł: 30
Dołączył: 19.02.2003
Skąd: Tychy

Ostrzeżenie: (0%)
-----


Nie da się bez podzapytania.


--------------------
Zapraszam na mój php blog, tworzenie stron.
Go to the top of the page
+Quote Post
koskitos
post
Post #8





Grupa: Zarejestrowani
Postów: 149
Pomógł: 0
Dołączył: 18.04.2004
Skąd: Z nikąd

Ostrzeżenie: (30%)
XX---


a jak zrobic, aby w ramce pasek przewijania po otworzeniu strony był przewinięty na dół...


--------------------
kOskiToS :D
Go to the top of the page
+Quote Post
TomASS
post
Post #9





Grupa: Zarejestrowani
Postów: 1 660
Pomógł: 13
Dołączył: 9.06.2004
Skąd: Wrocław i okolice

Ostrzeżenie: (0%)
-----


Możesz wykorzystać do tego etykiety. Oraz window.location na początku strony.


--------------------
Go to the top of the page
+Quote Post
kszychu
post
Post #10





Grupa: Przyjaciele php.pl
Postów: 2 712
Pomógł: 23
Dołączył: 27.10.2003
Skąd: z kontowni

Ostrzeżenie: (0%)
-----


To jeszcze w kwestii ID: może zamiast id użyć pola datetime?


--------------------
"Coś się kończy, coś się zaczyna." Andrzej Sapkowski
Go to the top of the page
+Quote Post
Spirit86
post
Post #11





Grupa: Zarejestrowani
Postów: 607
Pomógł: 23
Dołączył: 8.09.2004
Skąd: Wrocław

Ostrzeżenie: (0%)
-----


Możesz zrobić tak:
Gdy listujesz wszystkie wypowiedzi, zliczaj je
  1. <?php
  2. $POLICZ_REKORDY = 0;
  3. while(PETLA)
  4. {
  5. $POLICZ_REKORDY++;
  6. (...)
  7. }
  8.  
  9. ?>

po czym zadajesz pytanie
  1. DELETE
  2. FROM tabela
  3. ORDER BY id DESC LIMIT $POLICZ_REKORDY


na datetime ciężej się operuje...

Ten post edytował Spirit86 28.02.2006, 17:46:31


--------------------
Audio: Metallica, Soil, RHCP, OffSpring, Green Day, "Retro", Gorillaz, Disturbed, Coma
DB: MySQL 4.1 | php: 4.4.3 Pomogłem Ci? Wciśnij przycisk POMÓGŁ.
Go to the top of the page
+Quote Post
scanner
post
Post #12





Grupa: Zarząd
Postów: 3 503
Pomógł: 28
Dołączył: 17.10.2002
Skąd: Wrocław




Od pewnego czasu hołduję zasadzie - nigdy nie kasuj danych z bazy.
Po to te mechanizmy powstały, żeby przechowywać w nich dane.
To w kwestii Twojego kasowania wpisów.

Jeśli koniecznie chcesz kasować lub (lepiej) wybierać wpis sprzed (lepiej: wybierać od) określonej daty, zaraz po ID dodaj pole timestamp. Przy dodawaniu nowego wpisu nadajesz mu wartośc
  1. NOW()
i teraz:
1. Aby usunąć:
  1. DELETE *
  2. FROM foo
  3. WHERE timestamp_field < DATE_SUB( NOW(), INTERVAL 30 DAY )

2. Aby wybrać:
  1. SELECT *
  2. FROM foo
  3. WHERE timestamp_field > DATE_ADD( NOW(), INTERVAL 30 DAY )


Nie potrzeba subselectów...
NIe trzeba niczego liczyć....
Wystarczy wiedzieć, że programowanie to coś więcej niż tylko stukanie w klawiaturę smile.gif


--------------------
scanner.info
Warto pamiętać: KISS, DRY
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 19.08.2025 - 23:04