插入的数据应与字段的数据类型相同
我们先创建一个goods表
1. create table `goods`( 2. id INT, 3. goods_name VARCHAR(10), 4. price DOUBLE );
下面插入一条语句
1. insert into `goods`(id ,goods_name,price) 2. values ('abc','小米手机',2000);
很显然是不可以的 因为id是一个整型 接收不了abc的类型!
小王同学打算再试着插入一条语句:
1. insert into `goods`(id ,goods_name,price) 2. values ('30','小米手机',2000);
居然可以通过 原因是 `30`这个字符串可以转化成整型的 但是abc 跟文字也不行!
数据的长度应该在列的规定范围内
insert into `goods`(id ,goods_name,price) values (40,'vivovivovivovivo手机',2000);
在values列出的数据位置必须与被加入的列的排列位置相应
1. insert into `goods`(id ,goods_name,price) 2. values ('华为手机',20,2000);
字符和日期类型的数据应该包含在单引号中🎮
例如:
1. insert into `goods`(id ,goods_name,price) 2. values (40,vivo手机,2000);
很显然是不行的! 因为goods_name是一个varchar类型 是字符串要用单引号引起来
列可以插入空值 前提是该字段允许为空🎮
insert into `goods`(id ,goods_name,price) values (30,'华为手机',NULL);
create table `goods`( id INT, goods_name VARCHAR(10), price DOUBLE NOT NULL);
如果在属性后面加了 NOT NULL之后就不允许插入空值了!就会出现图片上的错误
列名后面可以添加多条记录🎮
1. insert into `goods` 2. values (50,'三星手机',2300),(60,'海尔手机',1900);
向表中的所有字段添加数据时,可以不写前面的字段名称🎮
我们再向goods表中添加两条数据
如下图:
1. insert into goods 2. values(90,'苹果手机',5000),(45,'一加手机',4800);
默认值的使用🎮
我们可以指定某个列的默认值 ,可以在创建表时创建
create table `goods8`( id INT, goods_name VARCHAR(10), price DOUBLE NOT NULL DEFAULT 100);
insert into `goods`(id,goods_name) values(60,'格力手机');
显然 price 默认给的就是100!
以上就是小王同学带给大家的insert注意事项