PostgreSQL 特有数据库函数

所有这些函数都可以从 django.contrib.postgres.function 模块中获得。

RandomUUID

class RandomUUID

返回一个版本 4 的 UUID。

在 PostgreSQL < 13 上,必须安装 pgcrypto extension 。你可以使用 CryptoExtension 迁移操作来安装它。

使用实例:

  1. >>> from django.contrib.postgres.functions import RandomUUID
  2. >>> Article.objects.update(uuid=RandomUUID())

TransactionNow

class TransactionNow

返回数据库服务器上当前事务开始的日期和时间。如果你不在事务中,它将返回当前语句的日期和时间。这是对 django.db.models.function.Now 的补充,后者返回当前语句的日期和时间。

请注意,只有最外层的 atomic() 的调用才会设置事务,从而设置 TransactionNow() 返回的时间;嵌套调用会创建不影响事务时间的保存点。

使用实例:

  1. >>> from django.contrib.postgres.functions import TransactionNow
  2. >>> Article.objects.filter(published__lte=TransactionNow())
  3. <QuerySet [<Article: How to Django>]>