8

我正在使用本机 sql 查询,其中我有一个球员表,我加入了三次,首先获取击球手姓名,然后获取投球手姓名,然后获取外野手姓名。现在第一个连接有效,但接下来的两个也返回相同的名称,即击球手名称。

这是sql查询

 select 
    del.over_no , 
    del.delivery_no , 
    batsman.sname , 
    outType.name , 
    outBy.sname , 
    fielder.sname , 
    bep.runs, 
    bep.deliveries, 
    bep.fours, 
    bep.sixes

    from delivery del 
    INNER JOIN batsman_performance bep ON del.innings_id=bep.innings_id 
    INNER JOIN ref_player batsman ON del.batsman_id = batsman.id
    INNER JOIN ref_player outBy ON del.bowler_id = outBy.id
    LEFT OUTER JOIN ref_player fielder ON del.fielder_id1= fielder.id
    INNER JOIN ref_out_type outType ON del.out_type_id=outType.id
    and del.out_type_id IS NOT NULL 
    and del.innings_id=:innings_id 
    and bep.player_id = del.batsman_id
    order by over_no, delivery_no;

我没有为所选列使用别名,因为当我这样做时,hibernate 为我使用别名的任何列抛出异常

请求处理失败;嵌套异常是 javax.persistence.PersistenceException:org.hibernate.exception.SQLGrammarException:无法执行查询],根本原因是 java.sql.SQLException:找不到列“over_no”。

当我在我的 mysql 客户端上运行它并返回正确的数据集时,这个查询正在工作,但是当我在我的代码中运行它时,结果集以某种方式覆盖了 ref_player 表上的两个后续连接,让我在所有三列中都有击球手的名字,即 batsman.sname、outBy.sname 和 fielder.sname 列中的相同名称。

最近两天我被困在这里,请任何帮助都会很棒。

4

4 回答 4

5

尝试将您的选择包装在另一个选择语句中,它应该可以工作。我正在使用存储过程,但它不应该有任何区别

SELECT * FROM (

SELECT 
    del.over_no , 
    del.delivery_no , 
    batsman.sname , 
    outType.name , 
    outBy.sname , 
    fielder.sname , 
    bep.runs, 
    bep.deliveries, 
    bep.fours, 
    bep.sixes

    from delivery del 
    INNER JOIN batsman_performance bep ON del.innings_id=bep.innings_id 
    INNER JOIN ref_player batsman ON del.batsman_id = batsman.id
    INNER JOIN ref_player outBy ON del.bowler_id = outBy.id
    LEFT OUTER JOIN ref_player fielder ON del.fielder_id1= fielder.id
    INNER JOIN ref_out_type outType ON del.out_type_id=outType.id
    and del.out_type_id IS NOT NULL 
    and del.innings_id=:innings_id 
    and bep.player_id = del.batsman_id
    order by over_no, delivery_no
) AS subselection;

在上面,您实际上应该使用别名,否则您将有两列同名,这将引发错误

于 2012-09-11T18:54:11.157 回答
2

它是 Hibernate 错误跟踪的未决问题。

看这张票

也在hibernate论坛中。这清楚地表明这是一个休眠结束的错误。

参见 Hibernate 论坛讨论

于 2012-09-10T09:56:17.123 回答
0

Discovered the same issue. Another workaround is to use org.hibernate.Session#doWork and perform the query on the JDBC connection:

entityManager.unwrap(Session.class).doWork(new Work() {
  void execute(Connection c) throws SQLException {
   PreparedStatement stmt = c.prepareStatement("SELECT ... JOIN ... JOIN ...");
   try {
     ...
   } finally {
     stmt.close() 
   }
于 2013-06-12T09:16:08.607 回答
0

你试过改变吗

 order by over_no, delivery_no; 

 order by del.over_no, del.delivery_no;
于 2012-08-15T11:10:38.247 回答