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

JAVA开发Erp时日志报错:SQL 当 IDENTITY_INSERT 设置为 OFF 时,不能为表 ‘***‘ 中的标识列插入显式值

错误提示

### SQL: INSERT INTO sys_user  ( user_id, username, password,      status,   create_time,  update_time )  VALUES  ( ?, ?, ?,      ?,   ?,  ? )
### Cause: com.microsoft.sqlserver.jdbc.SQLServerException: 当 IDENTITY_INSERT 设置为 OFF 时,不能为表 'sys_user' 中的标识列插入显 式值。
;IDENTITY_INSERT 设置为 OFF 时,不能为表 'sys_user' 中的标识列插入显式值。; nested exception is com.microsoft.sqlserver.jdbc.SQLServerException: 当 IDENTITY_INSERT 设置为 OFF 时,不能为表 'sys_user' 中的标识列插入显式值。] with root cause
com.microsoft.sqlserver.jdbc.SQLServerException: 当 IDENTITY_INSERT 设置为 OFF 时,不能为表 'sys_user' 中的标识列插入显式值。

从错误信息来看,问题出在尝试向 sys_user 表中插入数据时,显式指定了标识列(通常是自增主键列)的值,而该表的 IDENTITY_INSERT 属性设置为 OFF。在 SQL Server 中,默认情况下,标识列(自增主键列)不允许显式插入值,必须由数据库自动生成。

错误原因

com.microsoft.sqlserver.jdbc.SQLServerException: 当 IDENTITY_INSERT 设置为 OFF 时,不能为表 'sys_user' 中的标识列插入显式值。
  • 标识列: 通常是指带有 IDENTITY 属性的列,例如 user_id
  • IDENTITY_INSERT: 控制是否可以将显式值插入到表的标识列中。
  • 默认行为: 默认情况下,IDENTITY_INSERTOFF,不允许显式插入标识列的值。

解决步骤

  1. 检查表结构:

    • 确认 sys_user 表中的 user_id 列是否具有 IDENTITY 属性。
  2. 决定解决方案:

    • 方案一: 移除插入语句中的 user_id 值,让数据库自动生成。
    • 方案二: 如果确实需要显式插入 user_id 值,临时启用 IDENTITY_INSERT

方案一:移除 user_id

如果你不需要显式指定 user_id 值,可以让数据库自动生成。修改插入语句如下:

INSERT INTO sys_user (username, password, status, create_time, update_time)
VALUES (?, ?, ?, ?, ?);
示例代码

假设你使用的是 JDBC 进行数据库操作,以下是示例代码:

String sql = "INSERT INTO sys_user (username, password, status, create_time, update_time) VALUES (?, ?, ?, ?, ?)";
try (PreparedStatement pstmt = connection.prepareStatement(sql)) {
    pstmt.setString(1, username);
    pstmt.setString(2, password);
    pstmt.setInt(3, status);
    pstmt.setTimestamp(4, new Timestamp(createTime.getTime()));
    pstmt.setTimestamp(5, new Timestamp(updateTime.getTime()));
    pstmt.executeUpdate();
} catch (SQLException e) {
    logger.error("Error inserting user: ", e);
}

方案二:启用 IDENTITY_INSERT

如果你确实需要显式插入 user_id 值,可以临时启用 IDENTITY_INSERT。但请注意,这种方法仅应在必要时使用,并且要注意潜在的风险。

启用 IDENTITY_INSERT
SET IDENTITY_INSERT sys_user ON;
插入数据
INSERT INTO sys_user (user_id, username, password, status, create_time, update_time)
VALUES (?, ?, ?, ?, ?, ?);
禁用 IDENTITY_INSERT
SET IDENTITY_INSERT sys_user OFF;
示例代码

以下是一个完整的示例,展示了如何在 Java 中使用 JDBC 启用和禁用 IDENTITY_INSERT 并插入数据:

String enableIdentityInsertSql = "SET IDENTITY_INSERT sys_user ON;";
String insertSql = "INSERT INTO sys_user (user_id, username, password, status, create_time, update_time) VALUES (?, ?, ?, ?, ?, ?)";
String disableIdentityInsertSql = "SET IDENTITY_INSERT sys_user OFF;";

try (Statement stmt = connection.createStatement()) {
    // 启用 IDENTITY_INSERT
    stmt.execute(enableIdentityInsertSql);

    try (PreparedStatement pstmt = connection.prepareStatement(insertSql)) {
        pstmt.setLong(1, userId);
        pstmt.setString(2, username);
        pstmt.setString(3, password);
        pstmt.setInt(4, status);
        pstmt.setTimestamp(5, new Timestamp(createTime.getTime()));
        pstmt.setTimestamp(6, new Timestamp(updateTime.getTime()));
        pstmt.executeUpdate();
    }

    // 禁用 IDENTITY_INSERT
    stmt.execute(disableIdentityInsertSql);
} catch (SQLException e) {
    logger.error("Error inserting user with explicit ID: ", e);
}

总结

  • 错误原因: 尝试向标识列插入显式值,而 IDENTITY_INSERT 设置为 OFF
  • 解决方法:
    1. 移除 user_id: 让数据库自动生成标识列的值。
    2. 启用 IDENTITY_INSERT: 临时启用 IDENTITY_INSERT 以允许显式插入标识列的值,但在操作完成后记得禁用它。

http://www.kler.cn/a/447576.html

相关文章:

  • OpenCV putText增加中文支持
  • 2014年IMO第4题
  • 构建高性能异步任务引擎:FastAPI + Celery + Redis
  • R 常用的内置软件包及功能介绍
  • 彻底认识和理解探索分布式网络编程中的SSL安全通信机制
  • PCL点云库入门——PCL库中点云数据拓扑关系之K-D树(KDtree)
  • 【5G】5G 无线协议 Radio Protocols(一)
  • 【大语言模型】ACL2024论文-30 探索语言模型在文本分类中的伪相关性:概念层面的分析
  • clickhouse-题库
  • VSCode中的Black Formatter没有生效的解决办法
  • 云计算赋能:TSP 问题求解与创新定价机制的全景剖析
  • MFC/C++学习系列之简单记录10——定时器
  • 基于SpringBoot+Vue的音乐网站-无偿分享 (附源码+LW+调试)
  • LSTM实现天气模型训练与预测
  • 编译原理复习---运行存储分配
  • 化工行业SAP管理系统:构建未来可持续生产模式的基石
  • 【新立电子】FPC的未来展望:柔性电子技术的无限可能
  • Python数学运算
  • jquery弹性动画特效插件DomLastic.js
  • 基于cobra开发的k8s命令行管理工具k8s-manager
  • Redis篇--常见问题篇9--其他一些问题
  • Coding Caprice - Linked-List 1
  • 【第八节】git与github
  • 【Leecode】Leecode刷题之路第88天之合并两个有序数组
  • Linux下基于最新稳定版ESP-IDF5.3.2开发esp32s3入门任务间的通讯-信号量【入门三】
  • 前端项目打包部署后,如何避免让用户强制去清除浏览器缓存