【问题标题】:How to batch insert incrementing IDs with Hibernate on MySQL?如何在 MySQL 上使用 Hibernate 批量插入递增的 ID?
【发布时间】:2013-03-06 09:38:08
【问题描述】:

我正在尝试使用 Hibernate 插入 n 条记录。标准就像从表中获取 MAX ID 并增加 ID 并保存记录。 ID 类似于TK020001

我获得了最大 ID,并为第一条记录增加了值。对于第二条记录,它必须采用最大 ID,但它采用前一个最大值。插入第一条记录后,我关闭了会话并刷新。

谁能给我在这种情况下插入记录的最佳方法(MySQL)?

【问题讨论】:

    标签: hibernate auto-increment


    【解决方案1】:

    尝试为您的连接将事务隔离级别设置为 READ_UNCOMMITTED。

    Work w = new Work()
    {
        @Override
        public void execute(Connection connection) throws SQLException
        {
            connection.setTransactionIsolation(Connection.TRANSACTION_READ_UNCOMMITTED);
        }
    };
    
    session.doWork(w);
    

    不要忘记将隔离级别设置回默认级别! 在我的公司,我们有一个小实用程序类,它保存默认级别并设置 READ_UNCOMMITTED (或任何其他)。动作完成后,我们再次使用漂亮的小实用程序将其设置回来。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2011-01-19
      • 1970-01-01
      • 2011-02-15
      • 2016-11-20
      • 2017-01-01
      • 1970-01-01
      • 2011-06-20
      • 2019-07-12
      相关资源
      最近更新 更多