java - 无法提取结果集。Oracle 数据库的问题
问题描述
我有一个与 Oracle 数据库应用程序连接的 Spring Boot。相同版本的应用程序适用于 MySQL,但是当我尝试对 Oracle 数据库执行一些请求时,它会抛出错误:
Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is org.springframework.dao.InvalidDataAccessResourceUsageException: could not extract ResultSet; SQL [n/a]; nested exception is org.hibernate.exception.SQLGrammarException: could not extract ResultSet] with root cause
"status":500,"error":"Internal Server Error","trace":"org.springframework.dao.InvalidDataAccessResourceUsageException: 无法提取 ResultSet;SQL [n/a];嵌套异常是 org.hibernate.exception。 SQLGrammarException: 无法提取 ResultSet\r\n\tat org.springframework.orm.jpa.vendor.HibernateJpaDialect.convertHibernateAccessException(HibernateJpaDialect.java:281)\r\n\tat org.springframework.orm.jpa.vendor.HibernateJpaDialect。 translateExceptionIfPossible(HibernateJpaDialect.java:255)\r\n\tat org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.translateExceptionIfPossible(AbstractEntityManagerFactoryBean.java:528)\r\n\tat org.springframework.dao.support.ChainedPersistenceExceptionTranslator.translateExceptionIfPossible( ChainedPersistenceExceptionTranslator.java:61)\r\n\tat 组织。springframework.dao.support.DataAccessUtils.translateIfNecessary(DataAccessUtils.java:242)\r\n\tat org.springframework.dao.support.PersistenceExceptionTranslationInterceptor.invoke(PersistenceExceptionTranslationInterceptor.java:154) 在 com.example.pawel.expense.controller .ExpenseController.createExpense(ExpenseController.java:67) ~[classes/:na] ECT...
所以这是我的这个功能的控制器方法:
@PostMapping("/expense")
ResponseEntity<Expense> createExpense(@Valid @RequestBody Expense expense) throws URISyntaxException {
Expense result = expenseRepository.save(expense);
return ResponseEntity.created(new URI("/api/expense/" + result.getId())).body(result);
}
还有我的费用模型
@NoArgsConstructor
@Data
@Table(name="expense")
@Entity
public class Expense {
@Id
@GeneratedValue(strategy= GenerationType.AUTO)
private Long id;
private Instant date;
private double amount;
private String description;
@ManyToOne
private Category category;
@ManyToOne
private User user;
// Getters and setters
这是我的application.properties
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.Oracle12cDialect
spring.jpa.properties.hibernate.ddl-auto=create-drop
spring.jpa.properties.hibernate.show-sql=true
spring.datasource.url=jdbc:oracle:thin:@localhost:1521:XE
spring.datasource.driver-class-name=oracle.jdbc.driver.OracleDriver
spring.datasource.username=system
spring.datasource.password=root
spring.datasource.initialization-mode=always
spring.datasource.validationQuery=SELECT 1
logging.level.org.hibernate.SQL=DEBUG
spring.server.compression.enabled=true
spring.jpa.database-platform=org.hibernate.dialect.Oracle12cDialect
spring.jpa.properties.hibernate.format_sql=true
解决方案
您应该像这样添加Hibernate Dialect
到您的application.properties
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.Oracle10gDialect
spring.jpa.database-platform=org.hibernate.dialect.Oracle10gDialect
或者为 Oracle 数据源创建一个Bean。按照本指南了解更多信息 为 Oracle 配置 Spring Boot
推荐阅读
- networking - 使用 NetworkManager 设置 OpenThread OTBR 无法设置 AP;bind9.service 无法运行
- python - 我想我在我的 Mac 上搞砸了我的 Python 环境
- r - 将分层 cox 模型的图与 R 中的其他模型进行比较
- python - 品脱:用“as_ratio=False”指定缩写单位
- rx-java - RxJava:通过 `debouncing()` 保护现有 API 方法免受用户过多的异步调用
- javascript - jquery-ui 对话框中的 ckeditor - Internet Explorer 11 工具下拉菜单问题
- python - 我们可以根据装饰器调用函数吗?
- concurrency - 我们什么时候应该选择锁定而不是无锁数据结构”
- ios - TableView重新加载前如何设置模型数据
- java - 在 Pramp 中无法识别 System.out.println?