索引与约束
约束
SQL 约束是对表列施加的规则。它们用于防止无效数据被输入到数据库中。
这确保了数据库中数据的准确性和可靠性。
默认值
DEFAULT
子句指定在执行 INSERT
时,如果用户未提供值,则使用的列的默认值。
如果列定义中没有附加显式的 DEFAULT
子句,
则该列的默认值为 NULL
。
显式的 DEFAULT
子句可以指定默认值为 NULL
、
字符串常量、BLOB 常量、带符号数字或任何用括号括起来的常量表达式。
非空
默认情况下,列可以包含 NULL 值。NOT NULL
约束强制列 不 接受 NULL 值。
这强制字段始终包含一个值,这意味着您不能插入新记录,
或在不向该字段添加值的情况下更新记录。
唯一
UNIQUE
约束确保列中的所有值都是不同的。
UNIQUE
和 PRIMARY KEY
约束都为列或列集提供了唯一性的保证。
PRIMARY KEY
约束自动具有 UNIQUE
约束。
每个表可以有多个 UNIQUE
约束,但每个表只能有一个 PRIMARY KEY
约束。
检查
CHECK
约束用于限制可以放置在列中的值范围。
如果您在列上定义 CHECK
约束,它将仅允许该列的某些值。
如果您在表上定义 CHECK
约束,它可以根据行中其他列的值限制某些列的值。
Currently not supported in SingleStore
主键
PRIMARY KEY
约束唯一标识表中的每条记录。
主键必须包含 UNIQUE
值,并且不能包含 NULL
值。
一个表只能有 一个 主键;在该表中,这个主键可以由单个或多个列(字段)组成。
复合主键
就像 PRIMARY KEY
,复合主键通过多个字段唯一标识表中的每条记录。
Drizzle ORM 提供了一个独立的 primaryKey
操作符来实现这一点:
外键
FOREIGN KEY
约束用于防止破坏表之间链接的操作。
FOREIGN KEY
是一个字段(或字段集合),在一个表中引用另一个表的 PRIMARY KEY
。
包含外键的表称为子表,包含主键的表称为引用表或父表。
Drizzle ORM 提供了几种声明外键的方法。
您可以在列声明语句中声明它们:
如果您想进行自引用,由于 TypeScript 的限制,您必须显式设置引用回调的返回类型或使用独立的 foreignKey
操作符。
要声明多列外键,可以使用专用的 foreignKey
操作符:
索引
Drizzle ORM 提供了 index
和 unique index
声明的 API:
IMPORTANT
对于 drizzle-kit@0.22.0
和 drizzle-orm@0.31.0
之前的版本,drizzle-kit
仅支持索引 name
和 on()
参数。
在 drizzle-kit@0.22.0
和 drizzle-orm@0.31.0
之后的版本中,drizzle-kit
支持所有字段!
从 0.31.0 开始,Drizzle ORM 的新索引 API 提供了用于索引创建的所有参数的集合:
IMPORTANT
截至目前,drizzle-kit
仅支持索引 name
和 on()
参数。
Drizzle ORM 提供了用于索引创建的所有参数集合:
Drizzle ORM 提供了用于索引创建的所有参数集合: