川朴老师 2022-07-22 08:30 采纳率: 75%
浏览 51
已结题

请问设置了unsigned后,为什么-255变成了256(我看有些文章说会插入失败)

img


请问设置了unsigned后,为什么-255变成了256(比如这篇文章说会插入失败:https://blog.csdn.net/fangkang7/article/details/98480858

  • 写回答

2条回答 默认 最新

  • CodeDevMaster Java领域优质创作者 2022-07-22 08:50
    关注

    简单说下unsigned属性:

    1.主要用来约束数据的范围,不能插入负数,如果插入负数默认为零。

    2.有符号包含负数,无符号不包含负数。对于正整数范围而言,无符号能存储的数据是有符号的两倍。

    分析说明:

    1.第一次插入,指定了主键值255

    2.第二次插入指定主键值-255,实际上由于unsigned属性导致插入的值实际是0,又因为主键值自增,故第二次插入id值为256

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
    川朴老师 2022-07-22 08:57

    回答得很详细,我想再问一下为什么我这里插入有符号不会报错

    回复
    CodeDevMaster 回复 川朴老师 2022-07-22 09:04

    1.插入-255后MySQL默认转换为0,插入位置刚好是id字段对应,id主键字段在插入数据时,只要为0,null等就会使用自增值。

    2.可以尝试换个字段进行插入尝试,你这里刚好是id主键的原因导致你产生的疑问。

    回复
    CodeDevMaster 回复 上菜猿 2022-07-22 09:05

    是的。

    回复
    展开全部4条评论
查看更多回答(1条)
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 7月29日
  • 已采纳回答 7月22日
  • 创建了问题 7月22日
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部