IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PL/SQL Oracle Discussion :

Oracle 10g - PLSQL - Allocation dynamique String


Sujet :

PL/SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Étudiant
    Inscrit en
    Mars 2007
    Messages
    163
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2007
    Messages : 163
    Par défaut Oracle 10g - PLSQL - Allocation dynamique String
    Bonjour à tous,

    Je voudrais savoir s'il existerait dans PLSQL une manière d'allouer des string dynamiquement. Je construit, en effet, une requête dynamiquement. Sa taille dépend d'un certains nombres de paramètres que je ne peux pas prévoir à l'avance.

    Merci d'avance.

  2. #2
    Expert confirmé Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Par défaut
    Ce n'est pas assez clair. Précisez aussi votre version d'Oracle, les choses évoluent.
    Déclarez une variable de type varchar2 et tant que votre requête ne dépasse pas le 32567 caractères c'est fait.

  3. #3
    Membre confirmé
    Étudiant
    Inscrit en
    Mars 2007
    Messages
    163
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2007
    Messages : 163
    Par défaut
    Citation Envoyé par mnitu Voir le message
    Ce n'est pas assez clair. Précisez aussi votre version d'Oracle, les choses évoluent.
    Déclarez une variable de type varchar2 et tant que votre requête ne dépasse pas le 32567 caractères c'est fait.
    Bonjour mnitu, Merci pour votre réponse.

    Dans le titre j'ai écrit Oracle 10g. Cela ne suffit-il plus?

    Oui, pour la taille maximale. Est-il possible de déclarer une taille en fonction du besoin. Un peu comme les varray pour lequel on peut faire un .extends(1) pour chaque nouvelle case.

  4. #4
    Expert confirmé Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Par défaut
    Citation Envoyé par mamid1706 Voir le message
    Bonjour mnitu, Merci pour votre réponse.

    Dans le titre j'ai écrit Oracle 10g. Cela ne suffit-il plus?
    Si si ça suffit. Au temps pour moi.

    Citation Envoyé par mamid1706 Voir le message
    Oui, pour la taille maximale. Est-il possible de déclarer une taille en fonction du besoin. Un peu comme les varray pour lequel on peut faire un .extends(1) pour chaque nouvelle case.
    Quand vous déclarer en C un tableau de 10000 char vous reservez 10000 octets de mémoire. Ce n'est pas pareil en PL/SQL avec varchar2 donc pourquoi voulez vous déclarer pilepoil la taille ?

  5. #5
    Membre confirmé
    Étudiant
    Inscrit en
    Mars 2007
    Messages
    163
    Détails du profil
    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mars 2007
    Messages : 163
    Par défaut
    Citation Envoyé par mnitu Voir le message
    Si si ça suffit. Au temps pour moi.



    Quand vous déclarer en C un tableau de 10000 char vous reservez 10000 octets de mémoire. Ce n'est pas pareil en PL/SQL avec varchar2 donc pourquoi voulez vous déclarer pilepoil la taille ?
    Ok, j'ai compris. En déclarant une chaîne VARCHAR2(30000), l'allocation se fait uniquement à l'initialisation de la chaîne.
    Merci.

Discussions similaires

  1. [Oracle 10G] Tableau Croisé Dynamique
    Par anayathefirst dans le forum PL/SQL
    Réponses: 3
    Dernier message: 01/02/2011, 10h05
  2. Réponses: 0
    Dernier message: 04/07/2010, 00h52
  3. un pivot 'dynamique' pour oracle 10g
    Par erigoal dans le forum PL/SQL
    Réponses: 14
    Dernier message: 03/06/2009, 21h45
  4. ORACLE 10g : récupérer la taille d'une colonne dynamiquement
    Par rafuoner dans le forum Administration
    Réponses: 3
    Dernier message: 11/03/2008, 14h59
  5. Réponses: 8
    Dernier message: 05/03/2007, 11h18

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo