表空间可被指定给特定模型生成的数据表,通过在该模型的 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 会忽略所有与表空间相关的选项。
在模型中添加自定义方法会给你的对象提供自定义的“行级”操作能力。与之对应的是类 Manager的方法意在提供“表级”的操...
Java Swing教程 -Java Swing JPanelJPanel是用于其他组件的容器。我们可以设置其布局管理器,边框和背景颜色。JPanel组相关组件...
Java Swing教程 -Java Swing JTreeJTree用于以树状结构显示分层数据。JTree中的每个项目都称为节点。节点还被分类为分支节点或叶...
我们将通过一个简单的 Demo 来阐述 MyBatis-Plus 的强大功能,在此之前,我们假设您已经:拥有 Java 开发环境以及相应 IDE熟...
MyBatis-Plus 条件构造器-AbstractWrapperlikeLeft(R column, Object val)likeLeft(boolean condition, R column, Obj...