Drukowana wersja tematu

Kliknij tu, aby zobaczyć temat w orginalnym formacie

Forum PHP.pl _ MySQL _ Przechowywanie niekompletnych dat

Napisany przez: sabat24 11.01.2018, 12:57:29

Chcę zapisać do bazy datę: "1900-12-00" dla pola DATE. Mój sql_mode składa się wyłącznie z ALLOW_INVALID_DATES - wedle dokumentacji baza powinna przyjąć taką datę, ale z jakiegoś powodu konwertuje mi to na 1899-11-30

Jest jakieś inne ustawienie w bazie, które wymusza taką konwersję?

Napisany przez: nospor 11.01.2018, 12:59:35

Mozna spytac czemu 00? Byc moze zle podchodzisz do sprawy?

Napisany przez: sabat24 11.01.2018, 13:04:16

Co ciekawe powyższy wynik otrzymuję wpisując zapytanie w Laravelu przez eloquent model. W przypadku, gdy zrobię to bezpośrednio na bazie to już otrzymuję inny rok: 1900-11-30

Co do "00" - nie zawsze znana jest data dzienna, a nie zawsze nawet miesięczna. Tylko rok jest pewny, że będzie podany. Natomiast taką mam zastaną architekturę, więc wolałbym nie zmieniać mechanizmu w serwisie.

Napisany przez: aras785 11.01.2018, 13:55:10

To po prostu dodaj 01 i koniec Twoich problemów... Porównywać zawsze możesz < zamiast <=

Napisany przez: sabat24 11.01.2018, 13:58:36

Nie mogę, gdyż chcę odróżnić daty 1900-12-00 od 1900-12-01, co oznacza: data dzienna nieznana od 1 grudnia 1900. Aczkolwiek ten problem będzie już rozwiązywał autor struktury serwisu.

Mi bardziej chodzi o ciekawość, jakie ustawienia powoduje wymuszenie konwertowania przez bazę daty i jak to wyłączyć. Nie mogę tego znaleźć w docu.

Napisany przez: aras785 11.01.2018, 14:11:15

Sprawdziłem u siebie na MYSQL 5.6.26 i data normalnie jest zapisywana (typ kolumny DATE)

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)