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 18/06/2007, 09h15   #1
Invité de passage
 
Inscription : juin 2007
Messages : 11
Détails du profil
Informations forums :
Inscription : juin 2007
Messages : 11
Points : 4
Points : 4
Par défaut MySQL 5 Probleme Data Truncated

Bonjour,

Voila maintenant plusieurs jours que je travail sur la migration d'une base de données de MySql 3.2 a MySql 5

Je crée une table:


Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
CREATE TABLE table (
  id_news int(11) NOT NULL auto_increment,
  date_creation timestamp(14) NOT NULL,
  date_publication timestamp(14) NOT NULL,
  date_validite timestamp(14) NOT NULL,
  titre text,
  new_titre_borne varchar(255) default ' ',
  resume text NOT NULL,
  description text,
  image varchar(255) default NULL,
  align enum('0','1') default NULL,
  lien varchar(255) default NULL,
  actif enum('0','1') default NULL,
  difusion enum('0','1') NOT NULL default '0',
  priority int(11) NOT NULL default '0',
  PRIMARY KEY  (id_news),
  KEY date_validite (date_validite),
  KEY actif (actif),
  KEY difusion (difusion),
  KEY priority (priority)
) TYPE=MyISAM;
Et je ne peux pas insérer de données dedans.
Lors de l'insertion :
Code :
1
2
INSERT INTO table VALUES (26,20030606152040,20030130000000,00000000000000,
'Test',' ','','','','0','_localsearch.php?','1','',1);
Il me marque l'erreur : Data truncated for column difusion.
Apparemment il n'accepte pas le null pour le type enum et le default ne marche pas...

Quelqu'un aurait une idée...???
whichgirl0909 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 18/06/2007, 09h51   #2
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
Tu confonds le NULL avec la chaîne vide ('').

Code :
1
2
INSERT INTO table VALUES (26,20030606152040,20030130000000,00000000000000,
'Test',' ','','','','0','_localsearch.php?','1',NULL,1);
Il serait en outre judicieux de ne pas mettre NOT NULL dans la définition de ta colonne difusion...
__________________
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 18/06/2007, 13h27   #3
Invité de passage
 
Inscription : juin 2007
Messages : 11
Détails du profil
Informations forums :
Inscription : juin 2007
Messages : 11
Points : 4
Points : 4
Merci d'avoir pris le temps de regarder...

Malheureusement, je en pense pas que NULL soit une solution puisque je ne dois pas avoir de valeur null dans ma base.

C'est d'ailleur pour cela que je veux à tout pris que la valeur pas defaut soit selectionné dans le cas ou l'on ne mets rien.

J'ai trouvé une solution qui ne me convient pas vraiment, car je devrais modifier tout le script sql de creation de la base de données qui est assez long.

La solution est :

INSERT INTO t_news( id_news , date_creation , date_publication , date_validite , titre , new_titre_borne , resume , description , image , align , lien , actif , priority )
VALUES (26,20030606152040,20030130000000,00000000000000,'test',' ','test','','','0','_localsearch.php?keyword=banon&srcModule=4','1',1);

Ce script me permet donc de prendre la valeur par défaut du enum. Seulement voila j'aimerai bien ne pas à avoir à modifier tout

Merci encore
whichgirl0909 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 18/06/2007, 14h36   #4
Membre chevronné
 
Avatar de pop_up
 
Inscription : avril 2006
Messages : 833
Détails du profil
Informations personnelles :
Localisation : France, Rhône (Rhône Alpes)

Informations forums :
Inscription : avril 2006
Messages : 833
Points : 690
Points : 690
Pour inserer quelque chose dans ton champ diffusion, tu peux pas utiliser une variable ?

du style

si on met rien alors ma variable = '0'
sinon ma variable = ce que tu veux mettre

inserer la variable

non ?
pop_up est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 18/06/2007, 21h42   #5
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
- pour insérer la valeur par défaut, le + simple est encore d'utiliser le mot-clé DEFAULT...

Code :
1
2
 
INSERT INTO ... VALUES (..., DEFAULT) ;
- si tu ne veux pas changer ton PHP, il te suffit de mettre un trigger BEFORE INSERT qui transforme le '' en la valeur souhaitée
__________________
Antoun
Expert SQL, BO, Essbase

La bible d'Essbase est parue !
Antoun 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 20h49.


 
 
 
 
Partenaires

Hébergement Web