2015-06-11 51 views
13

這已在之前發佈,但我的問題有點不同。這是有問題的JPQL查詢:參數綁定的名稱不能爲空或爲空!對於命名參數,您需要在Java版本上使用@Param作爲查詢方法參數

@Query("SELECT NEW com.htd.domain.ShopOrder(po.id, po.po_number, " 
      + "po.due_date, po_part.id, po_part.part_quantity, " 
      + "part.id, part.part_number, part.part_description, " 
      + "part.plasma_hrs_per_part, part.grind_hrs_per_part, " 
      + "part.mill_hrs_per_part, part.brakepress_hrs_per_part) " 
      + "FROM Po po " 
      + "LEFT JOIN po.partList po_part " 
      + "LEFT JOIN po_part.part part " 
      + "LEFT JOIN po_part.part where po.id = :id") 
    List<ShopOrder> getShopOrder(long id); 

現在我也試着這樣做:

@Query("SELECT NEW com.htd.domain.ShopOrder(po.id, po.po_number, " 
      + "po.due_date, po_part.id, po_part.part_quantity, " 
      + "part.id, part.part_number, part.part_description, " 
      + "part.plasma_hrs_per_part, part.grind_hrs_per_part, " 
      + "part.mill_hrs_per_part, part.brakepress_hrs_per_part) " 
      + "FROM Po po " 
      + "LEFT JOIN po.partList po_part " 
      + "LEFT JOIN po_part.part part " 
      + "LEFT JOIN po_part.part where po.id = :id") 
    List<ShopOrder> getShopOrder(@Param(value="id")); 

但是,這給了我一個警告說:

[ERROR] org.apache.catalina.core.ContainerBase.[Tomcat].[localhost].[/]. 
[dispatcherServlet] - Servlet.service() for servlet [dispatcherServlet] in 
context with path [] threw exception [Request processing failed; nested 
exception is org.springframework.dao.InvalidDataAccessApiUsageException: 
Name for parameter binding must not be null or empty! For named parameters 
you need to use @Param for query method parameters on Java versions < 8.; 
nested exception is java.lang.IllegalArgumentException: Name for parameter 
binding must not be null or empty! For named parameters you need to use 
@Param for query method parameters on Java versions < 8.] with root cause 
java.lang.IllegalArgumentException: Name for parameter binding must not be 
null or empty! For named parameters you need to use @Param for query method 
parameters on Java versions < 8. 

正在執行的方法查詢是:

/** 
    * Generate Shop Orders. 
    */ 
    @RequestMapping(value = "/generateShopOrder/{id}", method = RequestMethod.PUT, produces = MediaType.APPLICATION_JSON_VALUE) 
    @Timed 
    public void generate(@PathVariable Long id) throws URISyntaxException { 
     System.out.println("po id to generate = " + id); 

     List<ShopOrder> shopOrders = po_partRepository.getShopOrder(id); 

     for(ShopOrder order: shopOrders) { 
      System.out.println("-------Printing Shop Orders" + order); 
     } 

    } 

建議?

------------ UPDATE ----------------

這似乎解決這個問題:

@Query("SELECT NEW com.htd.domain.ShopOrder(po.id, po.po_number, " 
      + "po.due_date, po_part.id, po_part.part_quantity, " 
      + "part.id, part.part_number, part.part_description, " 
      + "part.plasma_hrs_per_part, part.grind_hrs_per_part, " 
      + "part.mill_hrs_per_part, part.brakepress_hrs_per_part) " 
      + "FROM Po po " 
      + "LEFT JOIN po.partList po_part " 
      + "LEFT JOIN po_part.part part " 
      + "LEFT JOIN po_part.part where po.id = ?1") 
    List<ShopOrder> getShopOrder(Long id); 

不過現在我正在一個錯誤說:

[ERROR] org.apache.catalina.core.ContainerBase.[Tomcat].[localhost].[/]. 
[dispatcherServlet] - Servlet.service() for servlet [dispatcherServlet] in 
context with path [] threw exception [Request processing failed; nested 
exception is org.springframework.dao.InvalidDataAccessApiUsageException: 
org.hibernate.QueryException: could not instantiate class 
[com.htd.domain.ShopOrder] from tuple; nested exception is 
java.lang.IllegalArgumentException: org.hibernate.QueryException: could not 
instantiate class [com.htd.domain.ShopOrder] from tuple] with root cause 
java.lang.IllegalArgumentException: null 

ShopOrder:

public ShopOrder(long po_id, String po_number, LocalDate po_due_date, 
    long po_part_id, int part_quantity, long part_id, 
    String part_number, String part_decription, BigDecimal plasma_hrs, 
    BigDecimal grind_hours, BigDecimal mill_hrs, 
    BigDecimal breakpress_hrs) { 

     this.po_id = po_id; 
     this.po_number = po_number; 
     this.po_due_date = po_due_date; 
     this.po_part_id = po_part_id; 
     this.part_quantity = part_quantity; 
     this.part_id = part_id; 
     this.part_number = part_number; 
     this.part_decription = part_decription; 
     this.plasma_hrs = plasma_hrs; 
     this.grind_hours = grind_hours; 
     this.mill_hrs = mill_hrs; 
     this.breakpress_hrs = breakpress_hrs; 

    } 

Database tables

+0

你有什麼錯誤?什麼引發異常?堆棧跟蹤? –

+0

@NeilStockton回答更新了完整的堆棧跟蹤 – Drew1208

+0

@NeilStockton更新.... – Drew1208

回答

10

而不是使用:po.id =:ID只使用1 ....

@Query("SELECT NEW com.htd.domain.ShopOrder(po.id, po.po_number, " 
      + "po.due_date, po_part.id, po_part.part_quantity, " 
      + "part.id, part.part_number, part.part_description, " 
      + "part.plasma_hrs_per_part, part.grind_hrs_per_part, " 
      + "part.mill_hrs_per_part, part.brakepress_hrs_per_part) " 
      + "FROM Po po " 
      + "LEFT JOIN po.partList po_part " 
      + "LEFT JOIN po_part.part part " 
      + "LEFT JOIN po_part.part where po.id = ?1") 
    List<ShopOrder> getShopOrder(Long id); 
45

試試這個參數說明:

List<ShopOrder> getShopOrder(@Param("id") long id); 
+3

我覺得很奇怪,JPA不允許沒有值的@Param標籤使用相同的默認參數名稱作爲變量名稱。 –

+1

@AmrinderArora因爲變量名不可訪問 –

+1

@ er-han是的,但它肯定是可以的。例如:https://stackoverflow.com/questions/40526925/why-are-spring-data-repository-method-parameters-names-not-available-even-on-jav?noredirect=1&lq=1 –

相關問題