Précédent   Forum des professionnels en informatique > Bases de données > MySQL > SQL Procédural
SQL Procédural Forum d'entraide sur les triggers, les procédures stockées et les fonctions en MySQL
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 30/11/2007, 17h06   #1
Membre habitué
 
Inscription : octobre 2005
Messages : 641
Détails du profil
Informations forums :
Inscription : octobre 2005
Messages : 641
Points : 143
Points : 143
Par défaut Problème d'insertion avec double TIMESTAMP

Bonjour,

suite à une grande découverte... qu'il était impossible de mettre DEFAULT pour un champ de type DATE & Co; que seul l'utilisation de TIMESTAMP permet l'insertion automatique de la date à l'ajout d'un enregistrement...
Bref, je déside donc de passer mon champ DATETIME en TIMESTAMP pour profiter de cette spécificité.
Seulement voilà, évidemment, de nouvelles surprises pour moi !

Cela :
Code :
1
2
3
4
5
6
7
8
CREATE TABLE `t_admin` (
  `login` VARCHAR(20) NOT NULL, 
  `datetime_creation` TIMESTAMP NOT NULL, 
  `last_access` TIMESTAMP NOT NULL, 
  PRIMARY KEY (`login`) 
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
 
INSERT INTO `t_admin` (`login`) VALUES ('Toto');
donne :
Toto, '000-00-00 00:00:00', '2007-11-30 17:05:33'

Pourquoi y a des ZEROS ???????????
je suis à 2 doigts de passer sous PostgreSQL...

Merci d'avance et bon WE.
Tchupacabra est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 01/12/2007, 11h32   #2
Membre régulier
 
Inscription : octobre 2006
Messages : 121
Détails du profil
Informations personnelles :
Âge : 61

Informations forums :
Inscription : octobre 2006
Messages : 121
Points : 90
Points : 90
Bonjour,

Je pense qu'il faut définir une valeur par défaut, qq chose comme
timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP. Par contre il n'est pas possible d'avoir 2 champs dont la valeur par défaut est current_timestamp

Bon week end
Marc Salama
MarcS est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 02/12/2007, 02h02   #3
Rédacteur/Modérateur

 
Avatar de Antoun
 
Homme Antoine Dinimant
Consultant en Business Intelligence
Inscription : octobre 2006
Messages : 5 854
Détails du profil
Informations personnelles :
Nom : Homme Antoine Dinimant
Âge : 42
Localisation : France, Paris (Île de France)

Informations professionnelles :
Activité : Consultant en Business Intelligence
Secteur : Conseil

Informations forums :
Inscription : octobre 2006
Messages : 5 854
Points : 9 540
Points : 9 540
Par ailleurs, le domaine du TIMESTAMP est réduit, ça doit être 1970-2037...
__________________
Antoun
Expert SQL, BO, Essbase

La bible d'Essbase est parue !
Antoun est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/12/2007, 09h20   #4
Membre habitué
 
Inscription : octobre 2005
Messages : 641
Détails du profil
Informations forums :
Inscription : octobre 2005
Messages : 641
Points : 143
Points : 143
Bonjour à vous deux !
Citation:
Envoyé par MarcS Voir le message
Je pense qu'il faut définir une valeur par défaut, qq chose comme
timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP
je croyais qu'il était impossible de mettre DEFAULT pour un champ de type DATE...

Citation:
Envoyé par MarcS Voir le message
Par contre il n'est pas possible d'avoir 2 champs dont la valeur par défaut est current_timestamp
ça c'est pas bon pour moi...

Citation:
Envoyé par Antoun Voir le message
Par ailleurs, le domaine du TIMESTAMP est réduit, ça doit être 1970-2037...
Je sais bien... l'écart est suffisant pour ce que j'ai besoin. Cependant DATETIME ne permet (apparemment) pas une insertion automatique de la date / heure de l'insertion...

Alors comment avoir 2 champs remplis avec NOW() ?

Tchupacabra est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 03/12/2007, 09h23   #5
Membre régulier
 
Inscription : octobre 2006
Messages : 121
Détails du profil
Informations personnelles :
Âge : 61

Informations forums :
Inscription : octobre 2006
Messages : 121
Points : 90
Points : 90
Bonjour,

Je pense que cela doit être réalisable avec un trigger.

Bonne journée
Marc Salama
MarcS est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 07h33.


 
 
 
 
Partenaires

Hébergement Web