MySQL中怎样限制一个字段输入的值的范围
例如现在一个名为gender的字段,我想让这个字段只能插入“男”或“女”两个值,请问应该如何实现(最好能给出代码)?听说check约束在MySQL中不起作用,是不是真的?...
例如现在一个名为gender的字段,我想让这个字段只能插入“男”或“女”两个值,请问应该如何实现(最好能给出代码)?听说check约束在MySQL中不起作用,是不是真的?
展开
展开全部
可以设置枚举类型enum
CREATE TABLE `gender` (
`Gender` enum('男','女') DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8
追问
我测试了你这个方法,当插入非法值(不为“男”或“女”)时,数据库会插入空字符串,并没有报错,有没有插入非法值时会报错的方法呢?比如使用触发器可不可以?
追答
我这个方法会有警告的 ~~
虽然我也纠结过这个问题 但是一般有效验证一般就在程序部分实现就好了 不要给 数据库太多的压力 否则也是浪费资源 自己可以控制的就 控制一下吧~
展开全部
得看你这个字段是什么类型了,一般建表的时候会要求的,比如char(32)就限制这个字段只能输入32位
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
varchar(10),int(10)等等
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
这个限制,一般在页面限制,没必要在mysql限制。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询