zuicaidenage
V2EX  ›  问与答

mysql not null 失效?

  •  
  •   zuicaidenage · May 10, 2019 · 2152 views
    This topic created in 2565 days ago, the information mentioned may be changed or developed.

    我现在有一张表结构如下:

    CREATE TABLE `user` (
      `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
      `name` varchar(255) CHARACTER SET utf8 NOT NULL,
      `address` varchar(255) CHARACTER SET utf8 NOT NULL,
      PRIMARY KEY (`id`)
    ) ENGINE=InnoDB AUTO_INCREMENT=107393 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
    

    我设置了address字段not null,单条插入会报值为 null,插入多条则不报错。

    插入单条语句:

    INSERT into user(`name`,`address`) VALUES('xx',null);
    

    结果:

    [SQL]INSERT into user(`name`,`address`) VALUES('xqq',null)
    
    [Err] 1048 - Column 'address' cannot be null
    

    插入多条语句:

    INSERT INTO USER (`name`, `address`)
    VALUES
    	('xqq', NULL),
    	('qqq', NULL)
    

    结果:

    [SQL]INSERT INTO USER (`name`, `address`)
    VALUES
    	('xxx', NULL),
    	('yyy', NULL)
    
    受影响的行: 2
    时间: 0.008s
    
    
    

    看了下表确实成功了,这是为啥呢,求大佬指点迷津。

    1 replies    2019-05-10 13:52:08 +08:00
    robert233
        1
    robert233  
       May 10, 2019
    not null,能插入 null? 我建议你再仔细看看
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   972 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 28ms · UTC 20:06 · PVG 04:06 · LAX 13:06 · JFK 16:06
    ♥ Do have faith in what you're doing.