首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >MySql约束使特定字段的值大于零

MySql约束使特定字段的值大于零
EN

Stack Overflow用户
提问于 2011-04-23 21:37:59
回答 2查看 4.9K关注 0票数 3

我使用下面的MySql语法来创建一个带约束的表,以检查P_Id列的值是否大于零,但它仍然允许我添加小于0的值,如-1、-2等。

代码语言:javascript
复制
CREATE TABLE Persons(
    P_Id int NOT NULL ,
    LastName varchar( 255 ) NOT NULL ,
    FirstName varchar( 255 ) ,
    Address varchar( 255 ) ,
    City varchar( 255 ) ,
    CHECK (
        P_Id >0
    )
)

我是否在上面的结构中做错了什么,使得P_Id的值>0?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-04-23 22:11:25

检查约束在mysql中不起作用。你必须做一些技巧来模仿他们。请看这篇文章

http://forge.mysql.com/wiki/Triggers#Emulating_Check_Constraints

票数 2
EN

Stack Overflow用户

发布于 2019-02-20 23:57:09

您可以添加派生的

代码语言:javascript
复制
tinyint NOT NULL

列被称为

代码语言:javascript
复制
id_check

使用(例如)公式

代码语言:javascript
复制
(IF(id<1,NULL,1))

(许多其他可行的变种)

请注意,列名不区分大小写,因此最好将它们小写。

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

https://stackoverflow.com/questions/5764461

复制
相关文章

相似问题

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