Datum- en Tijdfuncties in MySQL
- Inleiding
- Datum- en tijdtypes
- Invoegen van data en tijden
- Uitlezen van data en tijden
- Functies voor het weergeven van specifieke informatie
- Rekenen met data en tijden
- Data in Engels of Nederlands formaat
- Slotwoord en referenties
- Reacties op deze tutorial
Invoegen van data en tijden
Bij het invoegen van data en tijden in de database zijn er een aantal dingen waar je rekening mee moet houden. Allereerst moet je ervoor zorgen dat je het juiste datatype gebruikt. Een tijd invoegen in een DATE veld gaat natuurlijk niet werken. Ook is het niet echt nuttig om een DATETIME veld te gebruiken als je alleen een datum op wilt slaan.Verder is het van belang dat je bij het invoegen let op het formaat van de datum of tijd. Gegevens horen ingevoegd te worden in het standaardformaat van het type veld waarin ze geplaatst worden. Een datum in een DATE veld zal dus altijd in het 'YYYY-MM-DD' formaat ingevoegd moeten worden. MySQL accepteert bij uitzondering ook formaten als YYYYMMDD of YYYY/MM/DD als DATE of YYYYMMDDHHMMSS als DATETIME, maar het is verstandig om je gewoon aan het standaard formaat te houden.
Voorbeeld 1: Invoegen van een datum
Code
1
2
2
INSERT INTO tabel (datumveld)
VALUES ('2007-07-10')
VALUES ('2007-07-10')
Om de huidige datum in te voegen is het verstandiger om gebruik te maken van de functie CURDATE().
Voorbeeld 2: Invoegen van de huidige datum met CURDATE()
Code
1
2
2
INSERT INTO tabel (datumveld)
VALUES (CURDATE())
VALUES (CURDATE())
Deze functie is echter niet bruikbaar als we het huidige tijdstip in zouden willen voegen. CURDATE() geeft namelijk alleen een datum. Voor het invoegen van het huidige tijdstip kunnen we de functie NOW() gebruiken.
Voorbeeld 3: Invoegen van het huidige tijdstip met NOW()
Code
1
2
2
INSERT INTO tabel (datumtijdveld)
VALUES (NOW())
VALUES (NOW())
Aangezien NOW() een heel tijdstip terug geeft, is het ook mogelijk om met deze functie een DATE of TIME in te voegen. In dat geval wordt alleen het benodigde gedeelte van de functie gebruikt.