这是数据库主键自增的固然性质所决定的,数据删除后,主键还是会继续增加的,即主键使用过一次将不会再次使用。
例如:这个表中有10条数据,主键为1-10不间断的数字,那删除第十条数据,继续插入的话,id则会变成11,而不是10。通俗的说就是主键使用过一次将不会再次使用。
每次插入则不需要为主键设置参数,数据库会根据设置的递增条件,自动给出主键值。则第一次插入后主键为1,第二次为2,依次递增。
扩展资料:
Mysql、SqlServer主键自动增长的设置方法:
1、在mysql中把主键定义为自动增长标识符类型
如果把表的主键设为auto_increment类型,数据库就会自动为主键赋值。例如:
createtablecustomers(idintauto_incrementprimarykeynotnull,namevarchar(15))insertintocustomers(name)values("name1"),("name2")
2、在MSSQLServer中,如果把表的主键设为identity类型,数据库就会自动为主键赋值。例如:
createtablecustomers(idintidentity(1,1)primarykeynotnull,namevarchar(15))insertintocustomers(name)values("name1"),("name2")identity包含两个参数,第一个参数表示起始值,第二个参数表示增量。
参考资料来源:百度百科-主键约束
来自MySQL的学习笔记,写的不对的地方大家多多指教哦
SELECT、DISTINCT、FROM、JOIN、ON、WHERE、GROUP BY、HAVING、SUM、COUNT、MAX、AVG、ORDER BY、LIMIT
SELECT->DISTINCT->FROM->JOIN->ON->WHERE->GROUP BY->HAVING->ORDER BY->LIMIT
必须字段:SELECT、FROM
可选字段:DISTINCT、JOIN、ON、WHERE、GROUP BY、HAVING、SUM、COUNT、MAX、AVG、ORDER BY、LIMIT
FROM->ON->JOIN->WHERE->GROUP BY(开始使用SELECT中的别名,后面的语句中都可以使用别名)->SUM、COUNT、MAX、AVG->HAVING->SELECT->DISTINCT->ORDER BY->LIMIT
FROM:从哪个表中检索数据
ON:关联条件,与join一起使用
JOIN:对需要关联的表进行关联
WHERE:过滤数据条件,执行顺序:自下而上、从右到左
GROUP BY:将过滤的数据进行分组,执行顺序:从左往右
SUM:求和
COUNT:数量统计
MAX:最大值
AVG:求平均值
HAVING:对分组的数据过滤条件,与group by一起使用
SELECT:查看结果集
DISTINCT:结果集去重
ORDER BY:排序,升序:ASC;降序:DESC
LIMIT:截取出目标页数据
详细用法会在后面进行补充
首先创建一张表,添加字段,表名字为:goodsmaster
添加数据的语法结构为:
添加数据可以是插入数据或插入查询的结果
1.1 插入数据
运行语句,查询结果:SELECT * FROM goodsmaster
部分字段有做非空约束,那么这边插入部分数据,验证下非空约束
上面的语句运行之后会报错,错误内容为“[Err] 1364 - Field 'barcode' doesn't have a default value”,即“barcode”这个字段有创建非空约束,表示这个字段不能为空,如果插入数据时不给这个字段赋值,那么就需要给它一个默认值。
部分字段没有默认值,可以为空,那么现在验证一下插入数据时,这些字段不进行赋值会有什么结果
运行语句,查询结果:SELECT * FROM goodsmaster
仔细看会发现,上面的语句中插入数据也没有插入“itemnumber”字段,这个字段有添加主键约束,不能为空,但由于设置了自增约束,所以没有赋值也会自动在当前字段最大值+1,这就是自增约束;
上面的语句显示没有进行赋值的字段会默认显示Null。
1.2 插入查询结果
MySQL 支持把查询的结果插入到数据表中,我们可以指定字段,甚至是数值,插入到数据表中。
语法结构为:
删除语句使用DELETE删除,语法结构为:
删除记录可以使用WHERE来筛选删除的数据,下面为删除“barcode”字段数据为006的记录
由于部分数据可以为空,所以再删除的时候,WHERE的过滤条件必须用到主键约束或者唯一性约束的字段。MySQL 的这种安全性设置,主要就是为了防止删除或者修改数据时出现误 *** 作,导致删除或修改了不相关的数据。
删除表中的全部数据
MySQL中用UPDATE来修改数据,语法结构为:
注意:不要修改主键字段的值。因为主键是数据记录的唯一标识,如果修改了主键的值,就有可能会破坏数据的完整性。
语法结构:
具体需要用到的关键字查看本文第一部分即可
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)