Précédent   Forum des professionnels en informatique > Bases de données > Oracle > PL/SQL
PL/SQL Forum d'entraide sur le PL/SQL
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 24/11/2010, 19h50   #1
Membre à l'essai
 
Avatar de Fiona08
 
Inscription : juillet 2008
Messages : 108
Détails du profil
Informations forums :
Inscription : juillet 2008
Messages : 108
Points : 21
Points : 21
Par défaut pl/sql curseur update entre deux tables

Salut à tous,

je cherche un exemple de procedure PL/SQL qui me permetra de faire un update entre 2 tables.
J'ai trouvé des exemples sur le Net qui ne font que le Update sur la meme table.

Soit la table a:
id_a, emp_a, rue_a, statut_a

Soit la table b:
id_b, emp_b, rue_b, statut_b

La table a et b sont constituées de la meme maniere. La seule difference est au niveau du statut.

Je dois faire un update sur la table b avec les valeurs issuent de la table a where statut_a = 'upd' et changer apres le staus de la table_b en table_b = 'Ins'

Comment faire cela avec une procedure et le cuseur?

Merci d'avance pour vos exemples.

Fiona
Fiona08 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/11/2010, 06h55   #2
Membre actif
 
Inscription : février 2007
Messages : 167
Détails du profil
Informations forums :
Inscription : février 2007
Messages : 167
Points : 161
Points : 161
Par défaut Pour comprendre

Salut Fiona,

Je comprends qu'il faut mettre à jour la table b.

Les champs mis à jours sont emp_b et rue_b qui prennent les valeurs de emp_a et rue_a de la table a.

Le rapprochement entre les tables se fait sur id_b = id_a.

Les id concernés sont ceux des lignes pour lesquelles statut_a = 'upd'

Est-ce bien cela ?

Pozzo
Pozzo est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/11/2010, 08h01   #3
Membre à l'essai
 
Avatar de Fiona08
 
Inscription : juillet 2008
Messages : 108
Détails du profil
Informations forums :
Inscription : juillet 2008
Messages : 108
Points : 21
Points : 21
Citation:
Envoyé par Pozzo Voir le message
Salut Fiona,

Je comprends qu'il faut mettre à jour la table b.

Les champs mis à jours sont emp_b et rue_b qui prennent les valeurs de emp_a et rue_a de la table a.

Le rapprochement entre les tables se fait sur id_b = id_a.

Les id concernés sont ceux des lignes pour lesquelles statut_a = 'upd'

Est-ce bien cela ?

Pozzo
Salut Pozzo,

oui c'est bien cela. Je cherche un exemple en PL/SQL(Oracle 10 g) sur le Net avec un cuseur mais je ne trouve que update sur une colonne d'une meme table.

Merci de me donner quelques exemples si vous avez. Je plante depuis
Fiona
Fiona08 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/11/2010, 11h19   #4
Membre expérimenté
 
Inscription : juillet 2007
Messages : 495
Détails du profil
Informations personnelles :
Localisation : France, Paris (Île de France)

Informations forums :
Inscription : juillet 2007
Messages : 495
Points : 585
Points : 585
Pas besoin de curseur, c'est possible en ensembliste et certainement plus rapide :
Code :
1
2
3
4
5
6
7
8
9
10
11
 
UPDATE table_b tb
SET (tb.emp_b, tb.rue_b, tb.statut_b) =
   (SELECT ta.emp_a, ta.rue_a, 'Ins'
    FROM table_a ta
    WHERE ta.id_a = tb.id_b
    AND ta.statut_a = 'upd')
WHERE EXISTS (SELECT 1
                      FROM table_a ta
                      WHERE ta.id_a = tb.id_b
                      AND ta.statut_a = 'upd')
Le WHERE EXISTS permet de limiter la mise à jour aux seuls enregistrements de la table table_b pour lesquels un rapprochement avec la table table_a a pu être fait. Sans quoi, la requête chercherait à mettre à jour tous les enregistrements, y compris ceux qui n'ont pas eu de rapprochement, ce qui la ferait planter.
__________________
Des chercheurs qui cherchent, on en trouve, mais des chercheurs qui trouvent, on en cherche !
dgi77 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/11/2010, 11h35   #5
Membre à l'essai
 
Avatar de Fiona08
 
Inscription : juillet 2008
Messages : 108
Détails du profil
Informations forums :
Inscription : juillet 2008
Messages : 108
Points : 21
Points : 21
Salut dgi77,

merci pour ta reponse. Mon encadreuer aimerai que j'utilise le langage PLSQL et le cuseur pour le faire.

Merci
Fiona
Fiona08 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/11/2010, 11h48   #6
Membre expérimenté
 
Inscription : juillet 2007
Messages : 495
Détails du profil
Informations personnelles :
Localisation : France, Paris (Île de France)

Informations forums :
Inscription : juillet 2007
Messages : 495
Points : 585
Points : 585
Dommage...
Pas le temps de faire un curseur.
__________________
Des chercheurs qui cherchent, on en trouve, mais des chercheurs qui trouvent, on en cherche !
dgi77 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/11/2010, 21h16   #7
Membre actif
 
Inscription : février 2007
Messages : 167
Détails du profil
Informations forums :
Inscription : février 2007
Messages : 167
Points : 161
Points : 161
Par défaut En PlSql

Salut Fiona,

Il existe plusieurs types de curseurs.
Voici un exemple de code possible :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
 
Declare
  -- Parcourt de la table a
  Cursor c_a IS
    SELECT id_a, emp_a, rue_a
      FROM table_a
     WHERE statut_a = 'upd'
     ORDER BY id_a;
Begin
  -- boucle sur la table a
  FOR c1 IN c_a Loop
    -- Mise à jour de la table b sur l'id_a courant
    UPDATE table_b SET emp_b = c1.emp_a, rue_b = c1.rue_a WHERE id_b = c1.id_a;
  End Loop;
End;
/
Dis moi si ça colle,

Pozzo
Pozzo est déconnecté   Envoyer un message privé Réponse avec citation 10
Vieux 27/11/2010, 01h14   #8
Membre à l'essai
 
Avatar de Fiona08
 
Inscription : juillet 2008
Messages : 108
Détails du profil
Informations forums :
Inscription : juillet 2008
Messages : 108
Points : 21
Points : 21
Hallo Pozzo,

un tres grand merci ça fonctionne. J'ai juste encore fait des petits changements.

Merci encore
fiona
Fiona08 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 17h14.


 
 
 
 
Partenaires

Hébergement Web