项目之前运行好好的, 保存数据的时候突然报错:
javax.servlet.ServletException: org.springframework.dao.InvalidDataAccessApiUsageException: Write operations are not allowed in read-only mode (FlushMode.NEVER/MANUAL): Turn your Session into FlushMode.COMMIT/AUTO or remove 'readOnly' marker from transaction definition.
到网上搜索后,发现: 在web.xml设置OpenSessionInViewFilter过滤器的话,会默认设置为FlushModeMANUAL ,
如果FlushMode是MANUAL或NEVEL,在操作过程中 hibernate会将事务设置为readonly,所以在增加、删除或修改操作过程中会出现以上错误, 如果在过滤加上这句就OK啦:
<init-param>
<param-name>flushMode</param-name>
<param-value>AUTO</param-value>
</init-param>
分享到:
相关推荐
session.setFlushMode(FlushMode.AUTO); ``` 2. **显式调用flush()**:如果你确定某些地方需要立即同步到数据库,可以在代码中显式调用`Session.flush()`。 ```java session.flush(); ``` 3. **使用...
org.springframework.dao.InvalidDataAccessApiUsageException: Write operations are not allowed in read-only mode (FlushMode.NEVER) - turn your Session into FlushMode.AUTO or remove 'readOnly' marker ...
<param-name>flushMode</param-name> <param-value>AUTO</param-value> </init-param> </filter> <filter-name>openSessionInViewFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> ``` ...
org.springframework.dao.InvalidDataAccessApiUsageException: Write operations are not allowed in read-only mode (FlushMode.NEVER) - turn your Session into FlushMode.AUTO or remove 'readOnly' marker ...
- **FlushMode.COMMIT**:在提交事务时清理缓存。 - **FlushMode.NEVER**:永不自动清理缓存,只有显式调用 `flush()` 方法才会清理缓存。 无论设置为何种清理模式,显式调用 `session.flush()` 都会导致缓存被清理...
例如,`FlushMode.NEVER`表示从不自动刷新,`FlushMode.AUTO`则会在某些操作后自动刷新。 在工程示例中,`FlushMode.doc`可能详细介绍了各种FlushMode的使用场景和效果,而`2级缓存.doc`应该包含了二级缓存的配置和...
4. **控制Flush模式**:可以设置`Session`的flush模式,如`FlushMode.NEVER`表示永不flush,`FlushMode.MANUAL`表示手动flush。但请注意,过度使用可能会导致数据一致性问题。 5. **显式调用update()或saveOrUpdate...
- 如:设置`setFlushMode(FlushMode.COMMIT)`来控制批量提交行为。 5. **性能优化** - 包括索引优化、查询优化等多方面。 - 使用Hibernate提供的工具和技术来提升应用的整体性能。 #### 五、实战案例 - **用户...
Spring MVC Hibernate Demo Hibernate 配置 数据库实体必须设置以下注解 @Entity @Id 自增主键必须设置以下注解,否则报错 @GeneratedValue(strategy = GenerationType.IDENTITY) ... <param>flushMode</param-nam
例如,`Session.flushMode()`和`Session.setBatchSize()`方法。 2. 延迟加载:Hibernate的懒加载机制可以降低内存消耗,但过多的延迟加载可能导致大量小查询,增加数据库压力。合理设计实体关系,适时使用立即加载...
7. **`FlushMode`**:用于指定会话何时刷新数据到数据库。 8. **`LockMode`**:用于指定获取数据时的锁定级别,如`READ`和`WRITE`。 #### 三、使用示例 ##### 1. 创建基本的`Criteria` ```java Session sess = ...
- Transaction的`commit()`调用:在提交事务前,若设置为`FlushMode.COMMIT`或`AUTO`,Session会先清除缓存,再执行SQL提交事务。 - 查询操作:`find()`或`iterate()`时,如果对象属性有变动,会先清理缓存以更新...
除了这种方式,还可以使用Query或Criteria API的`setFlushMode(FlushMode.MANUAL)`来手动控制批处理。或者,如果你需要更底层的控制,可以使用`Session`的`doWork()`方法直接执行SQL批处理。 在`...
- **FlushMode**:`Criteria`还允许设置`FlushMode`,控制何时将缓冲区中的更改同步到数据库,影响事务管理。 #### 三、实战案例 1. **创建Criteria实例** ```java Session session = HibernateUtil....
Criteria 和 DetachedCriteria 都可以使用Criterion 和 Projection 设置查询条件,可以设置 FetchMode(联合查询抓取的模式)、设置排序方式,对于 Criteria 还可以设置 FlushMode(冲刷 Session 的方式)和 ...
`sessionFactoryBeanName`参数指定了SessionFactory的bean名称,这里是`sessionFactory`,`flushMode`参数设置为`AUTO`,意味着在需要时自动提交事务。 3. **Struts2配置**: - `StrutsPrepareAndExecuteFilter` ...
4. **会话管理**:Hibernate的Session提供了beginTransaction、commit和rollback方法,用于处理事务。Session的save、update和delete方法用于对象的持久化操作。FlushMode和CacheMode则控制了Session何时将数据同步...
- 使用批处理:通过`flushMode`和`batch-size`设置,可以批量处理多个操作,提高效率。 - 只获取必要的数据:避免加载整个实体,使用`select new`构造函数或`fetch`属性限制关联关系的加载。 - 利用缓存:根据...
- 数据操作通常涉及事务,使用`Session`的`beginTransaction()`开始事务,`commit()`提交事务,`rollback()`回滚事务。 - 要注意处理异常,确保在发生错误时正确回滚事务。 7. **缓存** - Hibernate提供了二级...