Bonjour,
je cherche à mettre à jour un enregistrement dans une fonction pl/sql or j'obtiens le message d'erreur suivant:
ORA-14551: cannot perform a DML operation inside a query
que faut il faire ?
y a t'il une autre solution ?
Merci
Bonjour,
je cherche à mettre à jour un enregistrement dans une fonction pl/sql or j'obtiens le message d'erreur suivant:
ORA-14551: cannot perform a DML operation inside a query
que faut il faire ?
y a t'il une autre solution ?
Merci
effectivement, seuls les procédures supportent le dml (autre que select), pas les fonctions!Envoyé par beegood
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 SQL> create function f return number is begin delete emp; return 0; end; 2 / Function created. SQL> create procedure p is begin delete emp; end; 2 / Procedure created. SQL> select f from dual; select f from dual * ERROR at line 1: ORA-14551: cannot perform a DML operation inside a query ORA-06512: at "SCOTT.F", line 1 SQL> exec p PL/SQL procedure successfully completed. SQL> roll Rollback complete.
Si la fonction PL/SQL démarre une transaction autonome, cela peut marcher. Mais la transaction autonome démarrée ne peut pas voir les modifications de la transaction "appelante" et la fonction doit terminer la transaction qu'elle a démarrée par COMMIT ou ROLLBACK.
Bonjour,
as tu un exemple de transaction autonome ?
Merci
Voici un élément de réponse :
cf iciEnvoyé par SQLPro
"Ce que l'on conçoit bien s'énonce clairement,
Et les mots pour le dire arrivent aisément." Nicolas Boileau
"Expliquer empêche de comprendre si cela dispense de chercher"
Quiz Oracle : venez tester vos connaissances !
La FAQ Oracle : 138 réponses à vos questions
Aidez-nous à la compléter
Je crois que SQLpro parle de SQL Server et non d'Oracle: 2 SGBD qui respectent un certain niveau de SQL standard mais qui sont très différents à bien des points de vue
Cet exemple marche en Oracle 10 chez moi mais doit aussi marcher en Oracle 8 et 9 puisque je l'ai copié de la page 677 dans ce livre là: http://www.amazon.com/gp/product/159...g=UTF8&s=books
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53 SQL> SQL> drop table counter; Table dropped. SQL> SQL> create table counter ( x int, y int default null); Table created. SQL> SQL> insert into counter values (0, 0); 1 row created. SQL> commit; Commit complete. SQL> SQL> create or replace function f return number 2 as 3 pragma autonomous_transaction; 4 l_y int; 5 begin 6 update counter set y=1 where x = 0; 7 select y into l_y from counter where x = 0; 8 commit; 9 return l_y; 10 end; 11 / Function created. SQL> show errors No errors. SQL> SQL> select f from dual; F ---------- 1 SQL> SQL> select * from counter; X Y ---------- ---------- 0 1 SQL>
Partager