首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何在SQLite / MySQL中限制列值

如何在SQLite / MySQL中限制列值
EN

Stack Overflow用户
提问于 2011-06-16 12:21:48
回答 4查看 35.8K关注 0票数 23

我想限制SQL表中的列值。例如,列值只能是"car“、"bike”或"van“。我的问题是,如何在SQL中实现这一点,在数据库端实现这一点是个好主意,还是应该让应用程序限制输入。

我还打算在将来添加或删除更多的值,例如,"truck“。

我使用的数据库类型是SQLite和MySQL。

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2011-06-16 12:36:24

添加一个包含这些传输方式的新表,并使您的列成为该表的外键。将来可以向表中添加新的传输方式,而您的列定义保持不变。

通过这种构造,我最终会选择在DB级别进行规范,而不是在应用程序级别。

票数 36
EN

Stack Overflow用户

发布于 2011-06-16 12:41:47

可以,建议添加check约束。Check约束用于确保数据库中数据的有效性并提供数据完整性。如果在数据库级别使用它们,则使用数据库的应用程序将无法添加无效数据或修改有效数据,因此即使应用程序本身接受无效数据,数据也会变为无效。

在SQLite中:

代码语言:javascript
复制
create table MyTable
(
    name string check(name = "car" or name = "bike" or name = "van")
);

在MySQL中:

代码语言:javascript
复制
create table MyTable
(
    name ENUM('car', 'bike', 'van')
);
票数 9
EN

Stack Overflow用户

发布于 2011-06-16 12:36:00

您将使用check约束。在SQL Server中,它是这样工作的

代码语言:javascript
复制
ALTER TABLE Vehicles
ADD CONSTRAINT chkVehicleType CHECK (VehicleType in ('car','bike','van'));

我不确定这是否是美国国家标准协会的标准,但我确定MySQL也有类似的结构。

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6367063

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档