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 14/04/2005, 11h45   #1
Nouveau Membre du Club
 
Avatar de Kyti
 
Inscription : mars 2005
Messages : 182
Détails du profil
Informations forums :
Inscription : mars 2005
Messages : 182
Points : 29
Points : 29
Par défaut Talle des champs

Bonjour,
voilà j'ai une question bête, mais j'ai absolument besoin de le savoir avant de créer ma base.

j'ai des champs qui, pour un enregistrement donné, peuvent être très longs (genre 600 caractères), mais ces mêmes champs pour d'autres enregistrements, peuvent être nuls !!
donc il faut que je prévois une taille suffisante mais pour ça j'ai besoin de savoir si la taille de la base en mémoire est calculée en fonction de ce que l'on réserve, ou seulement de ce que l'on occupe ?

par exemple si je réserve 600, mais que je n'ai en fait que 10 caractères, ça va prendre 600 ou 10 en mémoire ?

je sais pas si c'est très clair

Merci beaucoup
__________________
Kyti
Kyti est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/04/2005, 15h46   #2
vic
Membre éprouvé
 
Inscription : août 2002
Messages : 430
Détails du profil
Informations forums :
Inscription : août 2002
Messages : 430
Points : 408
Points : 408
Envoyer un message via MSN à vic
Si tu as déclaré les colonnes en CHAR(N) ca prendra toujours N octets à stocker, par contre en VARCHAR(N) ca prendra juste la taille de la chaîne + 1 ou 2 octets pour stocker la longueur.
vic est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/04/2005, 09h21   #3
Expert Confirmé
 
Avatar de trotters213
 
Inscription : janvier 2005
Messages : 2 572
Détails du profil
Informations personnelles :
Âge : 26
Localisation : France, Gard (Languedoc Roussillon)

Informations forums :
Inscription : janvier 2005
Messages : 2 572
Points : 2 605
Points : 2 605

le problème c'est que si tu as souvent accès à ces colonnes en recherche ou en jointure, ça sera beaucoup plus long avec des VARCHAR qu'avec des CHAR (car il faut calculer la longueur et tout). De même pour la mise à jour qui sera bien plus rapide avec des CHAR qu'avec des VARCHAR.
Après tout dépends du nombre d'enregistrements que tu aura et de ce que tu va faire de cette colonne.
Deplus VARCHAR n'est pas limité à 255 caractères :
__________________
Pensez au tag
Les règles du Forum

Dev. Web : FAQ (X)HTML/CSS | Tutos (X)HTML | Tutos CSS

PHP : FAQ PHP | Tutos PHP | Benchmark PHP 5

SQL : Cours SQL
trotters213 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/04/2005, 09h59   #4
Nouveau Membre du Club
 
Avatar de Kyti
 
Inscription : mars 2005
Messages : 182
Détails du profil
Informations forums :
Inscription : mars 2005
Messages : 182
Points : 29
Points : 29
Bonjour,
merci pour vos réponses
en fait ces collonnes vont juste servir pour un affichage.
sinon on m'a parlé du type BLOB (ou un truc comme ça), ça sert à quoi :

merci !
__________________
Kyti
Kyti est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/04/2005, 10h00   #5
Nouveau Membre du Club
 
Avatar de Kyti
 
Inscription : mars 2005
Messages : 182
Détails du profil
Informations forums :
Inscription : mars 2005
Messages : 182
Points : 29
Points : 29
ah oui, et j'ai essayé de les déclarer en VARCHAR(600) mais quand j'ai réouvert la base, il avait transformé ça en TEXT ! mais text c'est pas limité à 255 ?
__________________
Kyti
Kyti est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/04/2005, 10h16   #6
Expert Confirmé
 
Avatar de trotters213
 
Inscription : janvier 2005
Messages : 2 572
Détails du profil
Informations personnelles :
Âge : 26
Localisation : France, Gard (Languedoc Roussillon)

Informations forums :
Inscription : janvier 2005
Messages : 2 572
Points : 2 605
Points : 2 605
non TEXT c'est limité mais c'est un gros truc (c'est un texte quoi) : la dernière fois que je l'ai utilisé c'était justement popur mettre du texte et c'était limité à 4000 caractères donc...
BLOB sert je crois à enregistrer des fichiers audio, image, ... des trucs lourd quoi.
A mon avis il faut que tu utilise TEXT.
__________________
Pensez au tag
Les règles du Forum

Dev. Web : FAQ (X)HTML/CSS | Tutos (X)HTML | Tutos CSS

PHP : FAQ PHP | Tutos PHP | Benchmark PHP 5

SQL : Cours SQL
trotters213 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/04/2005, 10h45   #7
Nouveau Membre du Club
 
Avatar de Kyti
 
Inscription : mars 2005
Messages : 182
Détails du profil
Informations forums :
Inscription : mars 2005
Messages : 182
Points : 29
Points : 29
ok merci
__________________
Kyti
Kyti est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/04/2005, 10h52   #8
Expert Confirmé
 
Avatar de trotters213
 
Inscription : janvier 2005
Messages : 2 572
Détails du profil
Informations personnelles :
Âge : 26
Localisation : France, Gard (Languedoc Roussillon)

Informations forums :
Inscription : janvier 2005
Messages : 2 572
Points : 2 605
Points : 2 605
pense au tag [Résolu]
__________________
Pensez au tag
Les règles du Forum

Dev. Web : FAQ (X)HTML/CSS | Tutos (X)HTML | Tutos CSS

PHP : FAQ PHP | Tutos PHP | Benchmark PHP 5

SQL : Cours SQL
trotters213 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 06h10.


 
 
 
 
Partenaires

Hébergement Web