Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [MySQL] Pomijanie rekordów w określonym przypadku
Rafik
post
Post #1





Grupa: Zarejestrowani
Postów: 14
Pomógł: 0
Dołączył: 10.06.2010
Skąd: Trzeszczany

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


Witam.
Posiadam tabelę zawierającą zamówione usługi, które pojawią się na fakturze. Struktura tabeli przedstawia się następująco:

  1. CREATE TABLE IF NOT EXISTS `fv` (
  2. `fv_id` smallint(5) UNSIGNED NOT NULL AUTO_INCREMENT,
  3. `fv_uid` smallint(5) UNSIGNED NOT NULL DEFAULT '0',
  4. `fv_product` varchar(255) NOT NULL,
  5. `fv_product_type` tinyint(1) NOT NULL DEFAULT '0',
  6. `fv_price` float(5,2) UNSIGNED NOT NULL DEFAULT '0.00',
  7. `fv_user` smallint(5) UNSIGNED NOT NULL DEFAULT '0',
  8. `fv_date` int(10) UNSIGNED NOT NULL DEFAULT '0',
  9. `fv_price_date` int(10) UNSIGNED NOT NULL DEFAULT '0',
  10. `fv_session` varchar(100) NOT NULL,
  11. `fv_closed` tinyint(1) UNSIGNED NOT NULL DEFAULT '0',
  12. `fv_period` tinyint(1) UNSIGNED NOT NULL DEFAULT '0',
  13. `fv_period_time` int(10) UNSIGNED NOT NULL DEFAULT '0',
  14. `fv_status` tinyint(1) UNSIGNED NOT NULL DEFAULT '0',
  15. `fv_email` tinyint(1) UNSIGNED NOT NULL DEFAULT '0',
  16. PRIMARY KEY (`fv_id`)
  17. ) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=14 ;


Problem przedstawia się następująco: kolumna fv_uid zawiera ID faktury, na której znajduje się dana usługa (więc może się powtarzać) a fv_date zawiera datę dodania usługi do faktury (w formacie UNIXowym). Wcześniej tworząc listę faktur pomijałem powtarzające się rekordy z fv_uid lecz zapomniałem o pewnej rzeczy: wraz z nowym miesiącem fv_uid zaczyna się od "1" więc w aktualnej sytuacji daną usługę wyświetla w fakturze z całkiem innego miesiąca. Czy da się coś zrobić na obecnej bazie czy np. dodać kolumnę zawierająca dany miesiąc oraz rok i wg. tego sortować dane?
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 2)
Mchl
post
Post #2





Grupa: Zarejestrowani
Postów: 855
Pomógł: 145
Dołączył: 17.07.2008
Skąd: High Memory Area

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


Kod
WHERE MONTH(FROM_UNIXTIME(fv_date)) = 7


Ale generalnie raczej przydałoby się to przekonstruować.

Go to the top of the page
+Quote Post
Rafik
post
Post #3





Grupa: Zarejestrowani
Postów: 14
Pomógł: 0
Dołączył: 10.06.2010
Skąd: Trzeszczany

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


Do ID faktury (fv_uid) dodałem datę i teraz id wygląda następująco: YYYYmmID (2010071) daje faktuję o numerze 1 w lipcu 2010. Kolejny numer faktury dodaje 1 do liczby powstałej wcześniej z daty i ID. Problem więc rozwiązany.
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: 20.08.2025 - 15:01