codecamp

Django4.0 模型和数据库-表空间(Tablespaces)

为表格申明表空间

表空间可被指定给特定模型生成的数据表,通过在该模型的 ​class Meta​ 中提供 ​db_tablespace选项。该选项也影响此模型中为 ManyToManyField 自动创建的数据表。
你可以用 ​DEFAULT_TABLESPACE ​配置为 ​db_tablespace ​指定一个默认值。这在配置内置的 Django 应用或其它你无法修改代码的应用的表空间时非常有用。

为索引申明表空间

你可以为 ​Index ​构造器传入 ​db_tablespace ​选项指定索引使用的表空间名。对于单个字段的索引,你可以向 ​Field ​构造器传入 ​db_tablespace ​选项,为字段列索引指定可选的表空间。若此列没有索引,会忽略该选项。
你可以用 ​DEFAULT_INDEX_TABLESPACE ​配置项为 ​db_tablespace ​指定一个默认值。
若未指定 ​db_tablespace ​和 ​DEFAULT_INDEX_TABLESPACE​,索引会在与数据表相同的表空间中创建。

一个例子

class TablespaceExample(models.Model):
    name = models.CharField(max_length=30, db_index=True, db_tablespace="indexes")
    data = models.CharField(max_length=255, db_index=True)
    shortcut = models.CharField(max_length=7)
    edges = models.ManyToManyField(to="self", db_tablespace="indexes")

    class Meta:
        db_tablespace = "tables"
        indexes = [models.Index(fields=['shortcut'], db_tablespace='other_indexes')]

本例中, ​TablespaceExample ​模型(即模型表和多对多表)创建的表会被存在 ​tables ​表空间。名称字段和多对多表的索引会被存在该 ​indexes ​表空间中。 ​data ​字段也会生成一个索引,但因为并未为其指定表空间,所以它会被默认存入模型的表空间 ​tables ​中。 ​shortcut ​字段的索引会被存入 ​other_indexes ​表空间。

数据库支持

PostgreSQL 和 Oracle 支持表空间。而 SQLite, MariaDB 和 MySQL 不支持。

若你使用的后端不支持表空间,Django 会忽略所有与表空间相关的选项。


Django4.0 多数据库-多数据库的局限性
Django4.0 数据库访问优化-使用标准数据库优化技巧
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

Django4.0 模型和数据库

Django4.0 处理HTTP请求

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }