ERRORE: manca DALLA clausola di voce per la tabella "Utenti"

0

Domanda

Sto usando postgresql e pgadmin e sono nuovo di questo. Ho una tabella "Utenti" che ha le seguenti colonne (Username, Name, Email, Phone, Discount, Password, token, serial, created_on, updated_on, points, reference). Stavo cercando di creare un trigger per la tabella in modo che ogni volta che una nuova inserire si verifica con un nome utente esistente nel settore di riferimento, i punti di username verrà incrementato di 50. Quindi ci sono due operazioni - aggiornare la tabella, inserendo i nuovi valori.

Ho cercato di creare un trigger funzione come questa:

create or replace function points()
returns trigger as 
$BODY$
BEGIN
        if 
        new."Users"."reference" in (old."Users"."username")
        then
        Insert into "Users"(Username,Name,Email,Phone,Discount,Password,token,serial,created_on,updated_on,points,reference)
         values(new.Username,new.Name,new.Email,new.Phone,new.Discount,new.Password,new.token,new.serial,new.created_on,new.updated_on,new.points,new.reference);
        
        
         update "Users"
         set old."Users"."points" = old."Users"."points" + 50
         where "Users"."username" = (select "Users"."username" from "Users" where new."Users"."reference" in (old."Users"."username"));
                                     
                                     
         end if;
    RETURN new;
END;
$BODY$
language plpgsql;

e un trigger come questo:

create trigger referece_points
after insert 
on "Users"
for each row
execute procedure points();

Ma quando cerco di inserire un nuovo valore, gli "Utenti" della tabella " ottengo il seguente errore:

ERROR: missing FROM-clause entry for table "Users" LINE 1: SELECT new."Users"."reference" in (old."Users"."username") ^ Query: SELECT new."Users"."reference" in (old."Users"."username") CONTEXT: PL/pgSQL function points() line 2 at IF
plpgsql postgresql triggers
2021-11-23 21:47:46
1

Migliore risposta

0

Nuovo composito tipo di variabile è correlata alla tabella aderito con trigger.

Il codice new."Users"."reference" non ha alcun senso. Si dovrebbe scrivere solo new."reference".

2021-11-24 16:27:42

In altre lingue

Questa pagina è in altre lingue

Русский
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................