Oracle
 sql >> Base de données >  >> RDS >> Oracle

Requête de mise à jour multiple Oracle

Ce qui suit suppose qu'un ITEM_CODE est affecté à un seul DEPARTMENT_CODE, car c'est simple et vous ne nous avez pas donné d'autres règles commerciales. Si cette hypothèse est fausse, vous devrez ajuster la logique en conséquence.

J'ai également intégré votre exigence selon laquelle la valeur existante de COMPETITOT.COMPETITOR_CODE n'est pas fiable.

Étant donné cette date de test :

SQL> select * from competitor
  2  /

STORE_CODE  ITEM_CODE DEPARTMENT_CODE COMPETITOR
---------- ---------- --------------- ----------
        11     912003              14 01
        11     912003              14 04
        11     912003              14 03
        11     912004              14 01
        11     912004              14 02
        11     912004              14 04
        11     914001              14 01
        11     914001              14 02
        11     914001              14 05

9 rows selected.

SQL>

Nous pouvons utiliser un ROW_NUMBER() analytique pour générer le handle nécessaire pour COMPETITOR_CODE :

SQL> update competitor c
  2  set competitor_code =
  3          (select decode (dr
  4                         , 1, 'Comp_1'
  5                         , 2, 'Comp_2'
  6                         , 3, 'Comp_3')
  7             from ( select row_number() over ( partition by x.item_code
  8                                                  order by x.rowid ) as dr
  9                           , x.rowid as row_id
 10                    from competitor x
 11                    where x.item_code in ( select item_code
 12                                           from item
 13                                           where  department_code = 14 ) ) l
 14             where c.rowid = l.rowid )
 15  /

9 rows updated.

SQL>

Et voici le résultat souhaité (sauf ajouts supplémentaires aux règles métier) :

SQL> select * from competitor
  2  /

STORE_CODE  ITEM_CODE DEPARTMENT_CODE COMPETITOR
---------- ---------- --------------- ----------
        11     912003              14 Comp_1
        11     912003              14 Comp_2
        11     912003              14 Comp_3
        11     912004              14 Comp_1
        11     912004              14 Comp_2
        11     912004              14 Comp_3
        11     914001              14 Comp_1
        11     914001              14 Comp_2
        11     914001              14 Comp_3

9 rows selected.

SQL>