Rechercher : dans
Par :

SQL - select en format texte d'un champ numér

Dernière réponse le 18 jun 2009 à 17:55:10 g1blem, le 18 jun 2009 à 10:38:23 
 Signaler ce message aux modérateurs

Bonjour,

j'utilise la requète suivante dans un progiciel qui se charge de générer un fichier au format excel (sans possibilité de changer le format généré)

Select CLIENT.nom, CLIENT.telprof,
From patients

Le numéro de téléphone est intégré comme une valeur numérique et donc le premier chiffre étant 0, celui-ci est supprimer car correspondant à un champ numérique

existe t'il un moyen de forcer le select à définir ce champ comme étant du texte,

ou un autre moyen qui me permettrait de ne pas"perdre" le premier 0

merci beaucoup pour votre aide

bonne journée

g1blem

Configuration: Windows XP Internet Explorer 7.0

Meilleures réponses pour « SQL select en format texte d'un champ numér » dans :
SQL - Commande SELECT VoirLe langage de manipulation de données Le SQL est à la fois un langage de manipulation de données et un langage de définition de données. Toutefois, la définition de données est l'oeuvre de l'administrateur de la base de données, c'est pourquoi la...

1

giheller, le 18 jun 2009 à 11:36:24

Bonjour,

si $numtel contient le n°

on peut faire :
$numtel=str_pad($numtel, 10, "0", STR_PAD_LEFT);
------------------------------------------------
J-L

Répondre à giheller

2

g1blem, le 18 jun 2009 à 14:23:48

Bonjour giheller et merci pour la réponse,

j'ai testé ça :

PATIENTS.pat_tel=str_pad(PATIENTS.pat_tel, 10, "0", STR_PAD_LEFT)
Select PATIENTS.pat_tel
From patients

et le progiciel m'envoi le message :

nous n'autorisons que des requètes de séléction

Y a t'il moyen de forcer le format directement dans la requète de sélection ??

merci d'avance

g1blem

Répondre à g1blem

3

garion28, le 18 jun 2009 à 14:31:28

Déja si tu utilise
Select CLIENT.nom, CLIENT.telprof,
From patients
comme requete alors ca ne risque pas de marcher :/

Répondre à garion28

4

g1blem, le 18 jun 2009 à 14:43:32

Bonjour garion28,

merci pour ton intervention

cependant, je ne colle pas toute la requète que je dois faire mais juste un petit extrait afin d'avoir la synthaxe qui m'aidera à sortir le champ en texte, puis je me débrouillerai pour l'inclure dans la requète intégrale.

la requète postée en second est exacte par rapport à la réalité (la première ne se basait que sur des champs inventés, car je pense que le nom des champs n'a aucune importance dans l'exemple).

aurais tu une idée sur la possibilité d'inclure dans le select une fonction permettant d'aboutir au résultat ?

d'avance merci

g1blem

Répondre à g1blem

5

garion28, le 18 jun 2009 à 15:10:37

La requete renvoi un ensemble de champ qui sont dans divers format, mais vu que je n'utilise pas de bdd pour mon vba, je ne peut pas trop t'aider

néanmoin essaye soit d'extraire les information séparément (1 selection par requete)
ou bien de mettre les info dans un tableau structuré (ou a plusieurs dimension si tu préfère)

(le php n'est pas mon truc ^^')

Répondre à garion28

6

g1blem, le 18 jun 2009 à 16:19:44

MERCI POUR TON AIDE GARION28

je ne peux pas extraire les données une par une puisqu'il me faut chaque ligne de données

quelqu'un aurait une solution à mon problème

merci

g1blem

Répondre à g1blem

7

Christounet, le 18 jun 2009 à 17:03:18

Bonjour,

Si j'ai bien compris ton problème, c'est que Excel supprime le premier 0 car il considère la colonne comme étant une colonne numérique. Si c'est le cas j'ai une petite question afin de peut-être te proposer une solution:
- Quelle base de données utilises-tu ? Access, Mysql, Sql Server ...

A plus On se donne des souvenirs quand on se quitte.
(Marcel Achard)

Répondre à Christounet

8

g1blem, le 18 jun 2009 à 17:08:04

Bonjour christounet

tu as tout à fait compris mon problème

par contre j'utilise un utilitaire dans le progiciel et je ne sais pas sur quelle base de données est hébergée la base.... je dirai paut-être sql server mais sans en être sur

Répondre à g1blem

9

Christounet, le 18 jun 2009 à 17:20:40

Bonjour,

Tu peux essayer le code suivant

Select CLIENT.nom, '+33/'+CLIENT.telprof
From patients 

Cela devrait concaténer ton numéro de téléphone avec les caractères '+33/' qui sont le préfixe international pour la France.
Le signe + est valable pour Sql Server, pour Mysql le code serait
SELECT CLIENT.nom, CONCAT('+33/',CLIENT.telprof) from patients
, si c'est Oracle, le code sera
SELECT CLIENT.nom, '+33/' || CLIENT.telprof from patients

A toi de voir ce qui fonctionne.
A plus On se donne des souvenirs quand on se quitte.
(Marcel Achard)

Répondre à Christounet

10

g1blem, le 18 jun 2009 à 17:34:54

Super Christounet c'est parfait comme cela

le premier code était le bon

merci mille fois,

j'ai simplement modifié le caractère à ajouter par # car avec +33 il restait en numérique et les chiffres trop long avait le format avec une puissance

que le dieu des informaticiens veille sur toi

encore merci

g+2blem xD

Répondre à g1blem

11

giheller, le 18 jun 2009 à 17:42:09

Mille excuses, j'avais zappé excel ma réponse était du php. ------------------------------------------------
J-L

Répondre à giheller

12

 g1blem, le 18 jun 2009 à 17:55:10

Giheller,

franchement ce n'est pas grave, et je remercie très sincèrement toutes les personnes comme toi des coups de mains donnés

Répondre à g1blem