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

SQL Oracle Discussion :

insert et not exists


Sujet :

SQL Oracle

  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    750
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 750
    Par défaut insert et not exists
    Bonjour,

    voici mon problème


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    create table aa_toto (c1 number primary key, c2 varchar2(30));
     
    insert into aa_toto values (1,'aaaaaaa');
     
    commit;
    Je n'ai pas de séquences et je voudrai insérer une ligne dans ma table en incrémentant la valeur de c1.
    je fais ça:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    insert into aa_toto
    SELECT NVL(MAX(c1),0)+1, 'bbbbbbb' from aa_toto
    Par contre je souhaiterais pouvoir insérer seulement si le champ c2 que je veux insérer n'existe pas déjà:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    insert into aa_toto
    SELECT NVL(MAX(c1),0)+1, 'aaaaaaa' from aa_toto
    WHERE NOT EXISTS(SELECT 1 FROM aa_toto where c2 = 'aaaaaaa')
    Et là mon insertion plante car il essai quand même d'insérer.
    En effet la requête suivante me retourne 1 :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    SELECT NVL(MAX(c1),0)+1 from aa_toto
    WHERE NOT EXISTS(SELECT 1 FROM aa_toto where c2 = 'aaaaaaa')
    Moi je voudrais que si le champ c2 qu'on veut insérer existe déjà il ne m'insère rien du tout.
    Je veux une solution purement SQL.
    Pas la peine de me dire de créer une séquence.

    merci de votre aide

  2. #2
    Membre chevronné Avatar de NGasparotto
    Inscrit en
    Janvier 2007
    Messages
    421
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 421
    Par défaut
    Un index unique sur c2 serait le plus approprie, ainsi qu'une sequence Oracle pour c1. Ce serait aussi "une solution purement SQL".

    Nicolas.

  3. #3
    Membre chevronné Avatar de NGasparotto
    Inscrit en
    Janvier 2007
    Messages
    421
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 421
    Par défaut
    Voici le code, a deconseiller abosulement pour ceux qui recherche un code resistant aux environement multi-users, etc :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    SQL> CREATE TABLE aa_toto (c1 number PRIMARY KEY, c2 varchar2(30));
     
    Table created.
     
    SQL>
    SQL> INSERT INTO aa_toto VALUES (1,'aaaaaaa');
     
    1 row created.
     
    SQL>
    SQL> commit;
     
    Commit complete.
     
    SQL> insert into aa_toto a
      2  select mx, str
      3  from  (select NVL(MAX(c1),0)+1 mx, 'aaaaaaa' str FROM aa_toto) b
      4  where str not in (select c2 from aa_toto);
     
    0 rows created.
     
    SQL> insert into aa_toto a
      2  select mx, str
      3  from  (select NVL(MAX(c1),0)+1 mx, 'bbbbbbb' str FROM aa_toto) b
      4  where str not in (select c2 from aa_toto);
     
    1 row created.
     
    SQL> insert into aa_toto a
      2  select mx, str
      3  from  (select NVL(MAX(c1),0)+1 mx, 'bbbbbbb' str FROM aa_toto) b
      4  where str not in (select c2 from aa_toto);
     
    0 rows created.
     
    SQL>
    Nicolas.

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    750
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 750
    Par défaut
    super merci

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. INSERT IF NOT EXISTS
    Par finiderire dans le forum Langage SQL
    Réponses: 12
    Dernier message: 27/03/2012, 17h44
  2. Selection de lignes + insertion if not exists
    Par tom741 dans le forum SQL
    Réponses: 5
    Dernier message: 20/10/2010, 16h37
  3. [MySQL] INSERT IF NOT EXISTS
    Par Iloyo dans le forum MySQL
    Réponses: 7
    Dernier message: 17/03/2010, 15h26
  4. Sunopsis ODI: Insertion if not exists
    Par Marie-Thérèse dans le forum ODI (ex-Sunopsis)
    Réponses: 1
    Dernier message: 06/08/2009, 10h43
  5. Insert .. where not exists
    Par Zolex dans le forum SQL Procédural
    Réponses: 11
    Dernier message: 02/03/2007, 11h26

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