Posiadam tabelę zawierającą zamówione usługi, które pojawią się na fakturze. Struktura tabeli przedstawia się następująco:
CREATE TABLE IF NOT EXISTS `fv` ( `fv_id` smallint(5) UNSIGNED NOT NULL AUTO_INCREMENT, `fv_uid` smallint(5) UNSIGNED NOT NULL DEFAULT '0', `fv_product` varchar(255) NOT NULL, `fv_product_type` tinyint(1) NOT NULL DEFAULT '0', `fv_price` float(5,2) UNSIGNED NOT NULL DEFAULT '0.00', `fv_user` smallint(5) UNSIGNED NOT NULL DEFAULT '0', `fv_date` int(10) UNSIGNED NOT NULL DEFAULT '0', `fv_price_date` int(10) UNSIGNED NOT NULL DEFAULT '0', `fv_session` varchar(100) NOT NULL, `fv_closed` tinyint(1) UNSIGNED NOT NULL DEFAULT '0', `fv_period` tinyint(1) UNSIGNED NOT NULL DEFAULT '0', `fv_period_time` int(10) UNSIGNED NOT NULL DEFAULT '0', `fv_status` tinyint(1) UNSIGNED NOT NULL DEFAULT '0', `fv_email` tinyint(1) UNSIGNED NOT NULL DEFAULT '0', PRIMARY KEY (`fv_id`) ) 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?