PL/Perl は Perl プログラミング言語を使用して PostgreSQL 関数を作成することができる、読み込み可能な言語です。
通常、PL/Perl は plperl という名前で "信頼された"プログラミング言語としてインストールされます。この設定では、セキュリティを確保するために、Perl の特定の操作は無効にされます。一般的には、制限される操作はその環境に作用するものです。これには、ファイルハンドル操作や require、 use(外部モジュール用) が含まれます。データベースバックエンドC 関数と同様、内部へのアクセスや PostgreSQL ユーザ ID 権限下の OSレベルのアクセスを行うことはできません。こうして、全ての非特権データベースユーザはこの言語を使用することができます。
制限のない Perl 関数の作成が望ましい場合があります。例えば、Perl 関数を使用してメールを送信するような場合です。この場合を扱うために、PL/Perl はまた "信頼されない" 言語として(通常plperluという名前で)インストールすることもできます。この場合は完全なPerl言語を使用することができます。PL/PerlU 関数の作成者は、その関数が必要のないことを行わないことに注意しなければなりません。この関数はデータベース管理者としてログインしたユーザが実行できることをすべて実行できるからです。データベースシステムはデータベースのスーパユーザにのみ信頼されない言語による関数作成を許可していることに注意して下さい。