首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在MySQL中使用检查约束来控制字符串长度

在MySQL中使用检查约束来控制字符串长度
EN

Stack Overflow用户
提问于 2010-06-12 09:20:15
回答 2查看 9.7K关注 0票数 3

我被一个问题搞得筋疲力尽!

我已经使用MySQL设置了我的第一个检查约束,但不幸的是,我遇到了一个问题。在插入测试失败的行时,无论如何都会插入该行。

结构:

代码语言:javascript
运行
复制
CREATE TABLE user (
  id INT UNSIGNED NOT NULL AUTO_INCREMENT,
  uname VARCHAR(10) NOT NULL,
  fname VARCHAR(50) NOT NULL,
  lname VARCHAR(50) NOT NULL,
  mail VARCHAR(50) NOT NULL,
  PRIMARY KEY (id),
  CHECK (LENGTH(fname) > 30)
);

insert语句:

代码语言:javascript
运行
复制
INSERT INTO user VALUES (null, 'user', 'Fname', 'Lname', 'mail@me.now');

fname列中的字符串长度应该太短,但无论如何都会插入它。

我很确定我在这里遗漏了一些基本的东西。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-06-12 09:28:08

MySQL doesn't enforce CHECK constraints, on any engine.

这让我不禁要问,为什么要将fname列声明为VARCHAR(50),但却要强制要求它只能有30个字符?

也就是说,唯一的替代方法是使用触发器:

代码语言:javascript
运行
复制
CREATE TRIGGER t1 BEFORE INSERT ON user
 FOR EACH ROW BEGIN

   DECLARE numLength INT;
   SET numLength = (SELECT LENGTH(NEW.fname));

   IF (numLength > 30) THEN
     SET NEW.col = 1/0;
   END IF;

END;
票数 7
EN

Stack Overflow用户

发布于 2018-06-02 12:01:27

如上所述,你必须使用触发器,MySQL不支持check,而且当你的触发器块中有多个语句时,比如声明变量或控制流,你需要以beginend开始,并将触发器封装在两个delimiters中:

注意:如果您使用MariaDB,请在第一个分隔符之后和第二个分隔符之前使用//,否则,如果您使用MySQL,请使用$$

代码语言:javascript
运行
复制
delimiter //

create trigger `user_insert_trigger` before insert on `user` for each row
begin
    declare maximumFnameLength int unsigned;
    declare fNameLength int unsigned;
    set maximumFnameLength = 30;
    set fNameLength = (select length(new.fNameLength));
    if (fNameLength > maximumFnameLength) then
        signal sqlstate '45000'
            set message_text = 'First name is more than 30 characters long.';
    end if;
end

//

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

https://stackoverflow.com/questions/3027118

复制
相关文章

相似问题

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