<?xml version="1.0" encoding="utf-8"?>
<rss version="2.0">
	<channel>
		<title><![CDATA[Forum PostgreSQL - ilość miesięcy]]></title>
		<link>https://forum.postgresql.org.pl/viewtopic.php?id=283</link>
		<description><![CDATA[Najświeższe odpowiedzi w ilość miesięcy.]]></description>
		<lastBuildDate>Tue, 01 Sep 2009 12:45:05 +0000</lastBuildDate>
		<generator>PunBB</generator>
		<item>
			<title><![CDATA[Odp: ilość miesięcy]]></title>
			<link>https://forum.postgresql.org.pl/viewtopic.php?pid=1228#p1228</link>
			<description><![CDATA[dzięki, 
rzucę okiem na planet, nie byłem tam jeszcze]]></description>
			<author><![CDATA[dummy@example.com (adamleon)]]></author>
			<pubDate>Tue, 01 Sep 2009 12:45:05 +0000</pubDate>
			<guid>https://forum.postgresql.org.pl/viewtopic.php?pid=1228#p1228</guid>
		</item>
		<item>
			<title><![CDATA[Odp: ilość miesięcy]]></title>
			<link>https://forum.postgresql.org.pl/viewtopic.php?pid=1227#p1227</link>
			<description><![CDATA[W postgresie klika lat, ale co dzień dowiaduje się jak mało wiem :).

Nie ma chyba czegoś takiego jak 
[quote]
ciekawe i proste przykłady do nauki
[/quote]
jednak wciąż najlepsza jest dokumentacja, własne doświadczenia no i fora internetowe.
Jest kilka niezłych forów internetowych a na stronie postgresq.org jest postgres planet gdzie często piszą ciekawe rzeczy.
Postgres jako darmowa baza danych wciąż jest chyba mało popularny w środowiskach produkcyjnych ale trzeba uczciwie przyznać że wydajnościowo wciąż przegrywa z orcale'm, chociaż ma trochę feature'ów których mi brakuje w oracle'u.
Wierz mi że jest wiele rzeczy w których postgres jest lepszy niż mysql (ale przyznaję szczerze nie leży mi mysql więc nie jestem obiektywny).]]></description>
			<author><![CDATA[dummy@example.com (rski)]]></author>
			<pubDate>Tue, 01 Sep 2009 12:41:19 +0000</pubDate>
			<guid>https://forum.postgresql.org.pl/viewtopic.php?pid=1227#p1227</guid>
		</item>
		<item>
			<title><![CDATA[Odp: ilość miesięcy]]></title>
			<link>https://forum.postgresql.org.pl/viewtopic.php?pid=1226#p1226</link>
			<description><![CDATA[dzięki, działa

długo siedzisz w postgresql?

może masz jakieś namiary na ciekawe i proste przykłady do nauki, dokumentacja jakoś mi nie leży, najlepsze są przykłady dla opornych :-)

W ogóle zauważyłem, że nie ma za dużo postów na temat postgresql-a. Wnioskuję, że albo wszyscy wszystko wiedzą, albo nie jest to popularna baza. Dla mnie przewagą nad mysql jest to że postgres obsługuje role co jest super sprawą. Do tej pory działałem w Accessie i tam grupy ułatwiają zycie.]]></description>
			<author><![CDATA[dummy@example.com (adamleon)]]></author>
			<pubDate>Tue, 01 Sep 2009 12:23:21 +0000</pubDate>
			<guid>https://forum.postgresql.org.pl/viewtopic.php?pid=1226#p1226</guid>
		</item>
		<item>
			<title><![CDATA[Odp: ilość miesięcy]]></title>
			<link>https://forum.postgresql.org.pl/viewtopic.php?pid=1225#p1225</link>
			<description><![CDATA[Powinno działać
[code]
postgres=# create function month_between(date,date) returns float as 'select abs(extract(year from age($1,$2))*12 + extract(month from age($1,$2))); ' language 'sql';
CREATE FUNCTION
postgres=# select month_between('03-03-2003','02-02-2002');
 month_between 
---------------
            13
(1 row)

postgres=# select month_between('01-01-2003','03-03-2004');
 month_between 
---------------
            14
[/code]]]></description>
			<author><![CDATA[dummy@example.com (rski)]]></author>
			<pubDate>Tue, 01 Sep 2009 12:09:40 +0000</pubDate>
			<guid>https://forum.postgresql.org.pl/viewtopic.php?pid=1225#p1225</guid>
		</item>
		<item>
			<title><![CDATA[ilość miesięcy]]></title>
			<link>https://forum.postgresql.org.pl/viewtopic.php?pid=1224#p1224</link>
			<description><![CDATA[Witam

Próbuję zrobić funkcję która wylicz różnicę miesięcy z dat.
taki ogólny przykład działa

SELECT EXTRACT(MONTH FROM TIMESTAMP '2001-06-16')-EXTRACT(MONTH FROM TIMESTAMP '2001-02-11');

Mam też taką funkcyjkę z internetu ale nie mogę dojść co ją boli

CREATE FUNCTION MONTHS_BETWEEN(DATE,DATE)
  RETURNS NUMERIC AS
'SELECT to_number((date($1)-date($2)),''999999999'')/31'
LANGUAGE 'sql'; 

dostaje taki błąd:

ERROR:  function to_number(integer, unknown) does not exist
LINE 1: ...THS_BETWEEN(DATE,DATE) RETURNS NUMERIC AS 'SELECT to_number(...
                                                                                                                   ^
HINT:  No function matches the given name and argument types. You might need to add explicit type casts.

Zmiana na:

CREATE FUNCTION MONTHS_BETWEEN(DATE,DATE)
  RETURNS NUMERIC AS
'SELECT EXTRACT(MONTH FROM TIMESTAMP date($1))-EXTRACT(MONTH FROM TIMESTAMP date($1))'
LANGUAGE 'sql'; 

też nic nie pomaga.

Czy ktoś ma może jakiś przykład działającej funkcji lub wie co tu trzeba poprawić?

Z góry dzięki]]></description>
			<author><![CDATA[dummy@example.com (adamleon)]]></author>
			<pubDate>Tue, 01 Sep 2009 11:36:19 +0000</pubDate>
			<guid>https://forum.postgresql.org.pl/viewtopic.php?pid=1224#p1224</guid>
		</item>
	</channel>
</rss>
