PostgreSQL
 sql >> Baza danych >  >> RDS >> PostgreSQL

Dodaj miesiące do daty w PostgreSQL

W PostgreSQL możemy użyć + operatora, aby dodać jeden lub więcej miesięcy do daty. Istnieje kilka opcji określania rzeczywistej liczby miesięcy.

Przykłady

Postgres pozwala nam określić interwały przy dodawaniu do dat. Możemy zatem określić month lub months :

SELECT date '2030-01-20' + interval '1 month';

Wynik:

2030-02-20 00:00:00

A w liczbie mnogiej:

SELECT date '2030-01-20' + interval '6 months';

Wynik:

2030-07-20 00:00:00

Określone w dniach

Możemy również użyć równoważnej liczby w dniach (lub tygodniach w tym przypadku):

SELECT date '2030-01-20' + interval '31 days';

Wynik:

2030-02-20 00:00:00

Oczywiście to, czy to odpowiada dokładnej liczbie miesięcy, będzie zależeć od rzeczywistej określonej liczby dni lub tygodni.

Możemy alternatywnie użyć liczby całkowitej, określając ją w dniach:

SELECT date '2030-01-20' + 31;

Wynik:

2030-02-20

Możemy to również zrobić w ten sposób:

SELECT date '2030-01-20' + integer '31';

Wynik:

2030-02-20

Wartości ujemne

Możemy również wykonywać arytmetykę dat z wartościami ujemnymi. Jeśli użyjemy wartości ujemnej z + znak, to podana liczba miesięcy zostanie odjęta od daty. Ale jeśli użyjemy go z - znak, a następnie zostanie dodany do daty.

Przykład:

SELECT date '2030-01-20' - interval '-6 months';

Wynik:

2030-07-20 00:00:00

Możemy zrobić to samo z opcją liczby całkowitej:

SELECT date '2030-01-20' - integer '-181';

Wynik:

2030-07-20

  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Alternatywny format wyjściowy dla psql

  2. Wzorce i modyfikatory szablonów do formatowania daty/godziny w PostgreSQL

  3. Uruchamianie wielu instancji PostgreSQL na jednym hoście

  4. Testowanie funkcji PostgreSQL, które wykorzystują i zwracają refcursor

  5. STRING_AGG() Funkcja w PostgreSQL