# PL/PgSQL-Skripte schreiben

## **PL/PgSQL-Code in der Skript-Engine**

In *Eliona* können Skripte nicht nur in Python, sondern auch in **PL/PgSQL** geschrieben werden. Dies ermöglicht die direkte Verarbeitung von SQL-Abfragen innerhalb der Skript-Engine.

***

## **Skript-Definition**

Beim Erstellen eines neuen **PL/PgSQL**-Skripts in der Skript-Engine wird automatisch eine Template-Funktion vorgeschlagen. Dieses Template dient als Ausgangspunkt für die Skripterstellung.

```sql
DO $$
DECLARE
    -- Hier können Variablen deklariert werden
BEGIN
    -- Hier können SQL-Abfragen und Operationen ausgeführt werden
END $$;
```

***

## **Beispiel: Zeitstempel aktualisieren**

Das folgende Beispiel zeigt, wie ein Skript den aktuellen Zeitstempel (`NOW()`) aus der Datenbank abruft und ihn für ein bestimmtes Asset (`asset_id = 1`) in der `heap`-Tabelle aktualisiert:

```sql
DO $$
    DECLARE r timestamptz;
BEGIN
    SELECT NOW() INTO r;
    UPDATE heap SET ts = r WHERE asset_id = 1;
END$$;
```

▷ *Das Skript speichert den aktuellen Zeitstempel in der `heap`-Tabelle für das Asset mit der ID `1`*

{% hint style="warning" %}
**Sicherheit beachten:** Direkte Datenbankänderungen sind sofort wirksam und können nicht rückgängig gemacht werden.
{% endhint %}


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://docs.buildings.ability.abb/collection/german-14.2-freezed/dokumentation/engineering/skript-engine/pl-pgsql-skripte-schreiben.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
