MySQL中怎样限制一个字段输入的值的范围

例如现在一个名为gender的字段,我想让这个字段只能插入“男”或“女”两个值,请问应该如何实现(最好能给出代码)?听说check约束在MySQL中不起作用,是不是真的?... 例如现在一个名为gender的字段,我想让这个字段只能插入“男”或“女”两个值,请问应该如何实现(最好能给出代码)?听说check约束在MySQL中不起作用,是不是真的? 展开
 我来答
friday5xue
游戏玩家

推荐于2018-02-28 · 非著名电竞玩家
知道小有建树答主
回答量:162
采纳率:100%
帮助的人:73.4万
展开全部

可以设置枚举类型enum  

CREATE TABLE `gender` (
   `Gender` enum('男','女') DEFAULT NULL
 ) ENGINE=InnoDB DEFAULT CHARSET=utf8
追问
我测试了你这个方法,当插入非法值(不为“男”或“女”)时,数据库会插入空字符串,并没有报错,有没有插入非法值时会报错的方法呢?比如使用触发器可不可以?
追答
我这个方法会有警告的 ~~
虽然我也纠结过这个问题 但是一般有效验证一般就在程序部分实现就好了 不要给 数据库太多的压力 否则也是浪费资源 自己可以控制的就 控制一下吧~
FYFLF123
2013-09-13
知道答主
回答量:16
采纳率:0%
帮助的人:4.4万
展开全部
得看你这个字段是什么类型了,一般建表的时候会要求的,比如char(32)就限制这个字段只能输入32位
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
松常青abc
2013-09-13 · TA获得超过149个赞
知道答主
回答量:75
采纳率:0%
帮助的人:17.1万
展开全部
varchar(10),int(10)等等
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
yifeng80
2013-09-13 · TA获得超过187个赞
知道答主
回答量:260
采纳率:0%
帮助的人:99.2万
展开全部
这个限制,一般在页面限制,没必要在mysql限制。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式