Mysql

关注公众号 jb51net

关闭
首页 > 数据库 > Mysql > MySQL数据格为空白或NULL

MySQL设置数据格为空白或NULL问题及解决

作者:白瑕

文章主要讨论了在处理数据库需求时将某些字段设置为空白的问题,初尝试直接传递空字符串,PHPMyAdmin提示需要三个值,实际是因第三列数据不足导致.后文提出可通过设置字段默认值为NULL或直接写入空字符串来解决;并指出NULL与空字符串的区别

前言

昨天打算建个数据库来做个项目, 有个需求是把数据库中的一些格子设置为空白,但是不知道怎么做,感觉直接传个空字符串进去也不能算是"空白;"

我先尝试了不传值(现在来看是真的有点蠢) ,然后PHPMyAdmin提示"这行要有仨值,你就给了俩"

甚麽意思呢, 比如第一列和第二列我都给了5个数据,那么现在这俩都是5行,但是第三列我只给了俩数据,这样3 4 5行都缺了一块,就会出现这个错误;

1. 设置为空白

如果需要某个格子为空白, 可以为其所在的字段设置默认值, 但是不能不传值,那会报错;

然后需要设为空白的位置写入值DEFAULT即可;

或者更直接一点直接往格子里给个空字符串…

但注意是空字符串,不要在引号中间再敲一个空格.

是的,一开始我也觉得 传进去一个空字符串这个格子也不能算真的"空了",但确实是应该这么做:

公式:

 [字段名] [字段类型]  DEFAULT '',

例:

INSERT INTO test1(id, name, password) VALUES(1, "张五", "王五"), (2, "张三", DEFAULT), (3, "王二麻子", DEFAULT), (4, "李四", DEFAULT), (4, DEFAULT, DEFAULT)
//name的默认值是NULL,所以这里的两个DEFAULT会显示不同的结果;

2. 设置为NULL

设置为NULL就和直接传个空白字符串不一样了,格子里会实实在在的存在一些东西,在MySQL中是会占用空间的。

这种方法是设置默认值为NULL,举个例子你要是只给1,2列传了数据,第三列没管,那第三列此时就全是NULL。

公式:

ALTER TABLE [数据表名称] MODIFY [字段名] [字段类型] DEFAULT NULL;

例:

ALTER TABLE index_nav MODIFY imgs VARCHAR(255) DEFAULT NULL;
//直接什么都不给imgs吧
INSERT INTO index_nav (url, texts)
VALUES ("./blogs.php","博客"),

 ("./columns","专栏"),

 ("./download.php","下载"),

 ("./qa.php","问答"),

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文