Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/jpa/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
以实体作为参数的Spring数据JPA自定义查询不';行不通_Spring_Jpa_Spring Data Jpa - Fatal编程技术网

以实体作为参数的Spring数据JPA自定义查询不';行不通

以实体作为参数的Spring数据JPA自定义查询不';行不通,spring,jpa,spring-data-jpa,Spring,Jpa,Spring Data Jpa,当我在Spring Data JPA中使用实体作为参数的自定义查询时,我得到一个异常: java.sql.SQLException:没有为参数1指定值 以下是相关实体。我有两个与@OneToOne关系的实体,如下所示: 汽车: 订单: @Entity @Table(name = "order") public class Order { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) @Column(name = "order_i

当我在Spring Data JPA中使用实体作为参数的自定义查询时,我得到一个异常:

java.sql.SQLException:没有为参数1指定值

以下是相关实体。我有两个与@OneToOne关系的实体,如下所示:

汽车:

订单:

@Entity
@Table(name = "order")
public class Order {

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "order_id")
private long id;

@OneToOne(mappedBy="order")
private Car car;
...
}
我还使用Spring Data JPA存储库创建了自定义查询,以按车查找订单:

public interface OrderRepository extends CrudRepository<Order, Long> {

Optional<Order> findByCar(Car car);

}
公共接口OrderRepository扩展了Crudepository{
可选findByCar(汽车);
}
但是,当我使用findByCar(carWithNonNullOrder)方法时,会出现以下错误:

2016-01-28 12:13:39494[main]警告SqlExceptionHelper-SQL错误:0,SQLState:07001 2016-01-28 12:13:39494[main]错误SqlExceptionHelper-未为参数1指定值 2016-01-28 12:13:39503[主]信息事务上下文-测试上下文的回滚事务[DefaultTestContext@61dde151testClass=OrderServiceIT,testInstance=com.carsystem.server。OrderServiceIT@b25b095,testMethod=shouldMakeOrder@OrderServiceIT,testException=org.springframework.dao.InvalidDataAccessResourceUsageException:无法提取结果集;SQL[n/a];嵌套异常为org.hibernate.exception.sqlgrammareexception:无法提取结果集,mergedContextConfiguration=[MergedContextConfiguration@507b79f7testClass=OrderServiceIT,locations='{classpath:context/app context.xml}',classes='{}',contextInitializerClasses='[]',activeProfiles='{}',propertySourceLocations='{},propertySourceProperties='{}',contextLoader='org.springframework.test.context.support.DelegatingSmartContextLoader',parent=[null]]]。 2016-01-28 12:13:39504[main]信息一般应用程序上下文-关闭org.springframework.context.support。GenericApplicationContext@ff5b51f:启动日期[Thu Jan 28 12:13:31 CET 2016];上下文层次结构的根 2016-01-28 12:13:39506[main]INFO tainerEntityManagerFactoryBean-关闭持久化单元“默认”的JPA EntityManager工厂
org.springframework.dao.InvalidDataAccessResourceUsageException:无法提取结果集;SQL[n/a];嵌套异常为org.hibernate.exception.sqlgrammareException:无法提取结果集 位于org.springframework.orm.jpa.vendor.HibernateJpaDialect.convertHibernateAccessException(HibernateJpaDialect.java:242) 如果可能,请访问org.springframework.orm.jpa.vendor.HibernateJpaDialect.translateException(HibernateJpaDialect.java:225) 位于org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.TranslateExceptionIffailable(AbstractEntityManagerFactoryBean.java:417) 在org.springframework.dao.support.ChainedPersistenceExceptionTranslator.TranslateExceptionIfEnabled(ChainedPersistenceExceptionTranslator.java:59) 位于org.springframework.dao.support.DataAccessUtils.translateIfNecessary(DataAccessUtils.java:213) 位于org.springframework.dao.support.PersistenceExceptionTranslationInterceptor.invoke(PersistenceExceptionTranslationInterceptor.java:147) 在org.springframework.aop.framework.ReflectiveMethodInvocation.procedue(ReflectiveMethodInvocation.java:179)上 位于org.springframework.data.jpa.repository.support.CrudMethodMetadataPostProcessor$CrudMethodMetadataPopulatingMethodInterceptor.invoke(CrudMethodMetadataPostProcessor.java:131) 在org.springframework.aop.framework.ReflectiveMethodInvocation.procedue(ReflectiveMethodInvocation.java:179)上 位于org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:92) 在org.springframework.aop.framework.ReflectiveMethodInvocation.procedue(ReflectiveMethodInvocation.java:179)上 位于org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:208) 位于com.sun.proxy.$Proxy41.findByCar(未知源) 位于com.carsystem.server.OrderMapper.map(OrderMapper.java:25) 在com.carsystem.server.OrderServiceImpl.listOrders(OrderServiceImpl.java:90) 位于com.carsystem.server.OrderServiceIT.shouldMakeOrder(OrderServiceIT.java:96) 在sun.reflect.NativeMethodAccessorImpl.invoke0(本机方法)处 位于sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 在sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)中 位于org.junit.runners.model.FrameworkMethod$1.runReflectVeCall(FrameworkMethod.java:47) 位于org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12) 位于org.junit.runners.model.FrameworkMethod.invokeeexplosive(FrameworkMethod.java:44) 位于org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17) 位于org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26) 位于org.springframework.test.context.junit4.statements.RunBeforeTestMethodCallbacks.evaluate(RunBeforeTestMethodCallbacks.java:75) 位于org.springframework.test.context.junit4.statements.RunAfterTestMethodCallbacks.evaluate(RunAfterTestMethodCallbacks.java:86) 位于org.springframework.test.context.junit4.statements.SpringRepeat.evaluate(SpringRepeat.java:84) 位于org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:271) 位于org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:254) 位于org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:89) 位于org.junit.runners.ParentRunner$3.run(ParentRunner.java:238) 位于org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:63) 位于org.junit.runners.ParentRunner.runChildren(ParentRunner.java:236) 在org.junit.runners.ParentRunner.access$000(ParentRu
public interface OrderRepository extends CrudRepository<Order, Long> {

Optional<Order> findByCar(Car car);

}
Order findOneByCar(Car car);
public interface OrderRepository extends JpaRepository<Order, Long> {

Order findByCar(Car car);

}