收起
简单说下unsigned属性:
1.主要用来约束数据的范围,不能插入负数,如果插入负数默认为零。
2.有符号包含负数,无符号不包含负数。对于正整数范围而言,无符号能存储的数据是有符号的两倍。
分析说明:
1.第一次插入,指定了主键值255
2.第二次插入指定主键值-255
,实际上由于unsigned
属性导致插入的值实际是0,又因为主键值自增,故第二次插入id值为256
回答得很详细,我想再问一下为什么我这里插入有符号不会报错
1.插入-255后MySQL默认转换为0,插入位置刚好是id字段对应,id主键字段在插入数据时,只要为0,null等就会使用自增值。
2.可以尝试换个字段进行插入尝试,你这里刚好是id主键的原因导致你产生的疑问。
报告相同问题?