当前位置: 首页 > news >正文

MySQL向自增列插入0失败问题

问题

在一次上线时,发现通过脚本添加的状态表中,待提交的状态不正确,本来应该是0,线上是101。

原因

默认情况下,MySQL对应自增列,认为0和null等价(因为mysql认为0不是最佳实践不推荐使用,其实这里我这个表主键不应该设为自增,设置习惯了),所以虽然insert中有0,也会被mysql忽略改用自动生成的值。

解决方案

1. 不使用自增

一般使用0,代表有特殊含义,这种表主键可以的化,不需要加入自增;

2. 设置sql_mode

如果确实要自增,又需要插入0值,那就需要设置sql_mode
在迁移脚本开头加入
set sql_mode = concat(@@sql_mode,' NO_AUTO_VALUE_ON_ZERO')

  • NO_AUTO_VALUE_ON_ZERO就是告诉mysql, 在0时,不使用自增值;
  • 注意该设置仅在本次会话中有效;
  • 设置sql_mode时,需要带上原有的sql_mode;
http://www.lryc.cn/news/398058.html

相关文章:

  • Python:Python基础知识(注释、命名、数据类型、运算符)
  • Protobuf: 大数据开发中的高效数据传输利器
  • MySQL 面试相关问题
  • java org.aeonbits.owner库介绍
  • YOLOv10改进 | 添加注意力机制篇 | 添加LSKAttention大核注意力机制助力极限涨点
  • 学习笔记——动态路由——IS-IS中间系统到中间系统(特性之路由撤销)
  • 智能无人机控制:STM32微控制器与机器学习集成(内附资料)
  • 力扣 454四数相加
  • Java面试题系列 - 第9天
  • 数据结构【顺序表】
  • 【JavaScript 报错】未捕获的类型错误:Uncaught TypeError
  • html+css+js随机验证码
  • WPS打开PDF文件的目录
  • 常见 Web漏洞分析与防范研究
  • 暗黑魅力:Xcode全面拥抱应用暗黑模式开发指南
  • 【游戏引擎之路】登神长阶(七)——x86汇编学习:凡做难事,必有所得
  • 在 Windows 平台搭建 MQTT 服务
  • jdevelope安装
  • 排序(一)——冒泡排序、直接插入排序、希尔排序(BubbleSOrt,InsertSort,ShellSort)
  • synchronized关键字详解(全面分析)
  • 数据建设实践之大数据平台(三)
  • TypeScript中的交叉类型
  • CNN -1 神经网络-概述2
  • 利用js实现图片压缩功能
  • 2024.7.10 刷题总结
  • ES6 async 函数详解 (十)
  • 【安全设备】入侵检测
  • 07浅谈大语言模型可调节参数tempreture
  • Redis数据同步
  • 快手矩阵源码,快速拥有自己的短视频矩阵