跳转到主要内容

Django的Postgres声明性函数

项目描述

django-pg-ddl-extras

一个微小的库,实现了Django的Postgres声明性函数定义。

需求

  • Python >= 3.7
  • Django >= 3.2

使用方法

在下面的示例中,我们创建了一个作为约束触发器部分运行的函数。

from django_pg_ddl_extras import (
    PostgresTriggerFunctionDefinition,
    ConstraintTrigger,
    TriggerEvent,
)
from django.db import models
from django.db.models.constraints import Deferrable

# Write a custom constraint in SQL
# In order to get picked up by the migration engine, we include the function definition
# as part of the class `Meta.constraints` list.
# Unfortunately, Django does not seem to have a cleaner way to define this yet.
custom_function = PostgresTriggerFunctionDefinition(
    name="my_function",
    body="""
DECLARE
BEGIN
    IF (TG_OP = 'DELETE') THEN
        RETURN OLD;
    END IF;
    IF NOT FOUND THEN
        RAISE EXCEPTION
            'This is an example constraint error'
            USING ERRCODE = 23514;
    END IF;
    RETURN NEW;
END;
    """,
)

class MyModel(models.Model):
    class Meta:
        constraints = [
            custom_function,
            ConstraintTrigger(
                name="my_trigger",
                events=[TriggerEvent.UPDATE, TriggerEvent.INSERT, TriggerEvent.DELETE],
                deferrable=Deferrable.DEFERRED,
                function=custom_function.as_func(),
            ),
        ]

项目详情


下载文件

下载适用于您平台的文件。如果您不确定选择哪个,请了解更多关于安装包的信息。

源分布

django-pg-ddl-extras-0.1.0.tar.gz (4.4 kB 查看散列)

上传时间

构建分布

django_pg_ddl_extras-0.1.0-py3-none-any.whl (5.2 kB 查看散列)

上传时间 Python 3

由以下支持