yuehoiwai 2019-09-01 19:47 采纳率: 0%
浏览 509
已采纳

JPA+Hibernate架構上可以使用HQL嗎?

我的項目的SQL語句原來是采用HQL的,現在轉用Spring Boot +JPA+Hibernate, 出現以下問題,我估計是因爲HQL與JPQL的差異所致,請問如果我想繼續用HQL可以嗎? 如果可以,如何配置?

請問我如何知道我在用HQL還是用JPQL呢,如果我在用JPQL,又如何改成用HQL呢?

  1. 代碼:
    @Entity
    public class Place extends Groupunit_Defined implements Interface_Entity
    {
    ......
    @ManyToOne(targetEntity=Place_Definer.class)
    @JoinColumn(name="Groupunit_Definer",nullable=false)
    private Place_Definer Groupunit_Definer;//

    .....
    }
    @Entity
    public class Place_Definer extends Groupunit_Definer
    {
    ......
    @Column(nullable=false,length=150)
    private String Classification;
    }

  2. SQL 語句
    "SELECT * FROM Place p WHERE p.Groupunit_Definer.Classification='Jurisdiction'"

3.hibernate 設置

spring.jpa.database = MYSQL
spring.jpa.show-sql = true
spring.jpa.hibernate.ddl-auto = update
spring.jpa.hibernate.naming-strategy = org.hibernate.cfg.ImprovedNamingStrategy
spring.jpa.properties.hibernate.dialect = org.hibernate.dialect.MySQL5Dialect

4.報錯

Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Unknown column 'Unit_Quantityp.Groupunit_Definer..Classification in 'where clause'

  • 写回答

5条回答 默认 最新

  • Lei_Da_Gou 2019-09-01 20:47
    关注

    JPA是规范,Hibernate只是JPA的一个实现而已,肯定可以用HQL啊,你看下是不是Unit_Quantity.Id这里有问题,类名是不是正确,Id是不是应该写成id,HQL语句里面的字段用的java的属性名,而不是数据库的字段名。有问题可以追问,解决了你的问题,请采纳下谢谢!!!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

问题事件

  • 已采纳回答 8月23日

悬赏问题

  • ¥15 关于#linux#的问题(输入输出错误):出现这个界面接着我重新装系统,又让修电脑的师傅帮我扫描硬盘(没有问题)用着用着又卡死(相关搜索:固态硬盘)
  • ¥15 cv::resize不同线程时间不同
  • ¥15 web课程,怎么做啊😭没好好听课 根本不知道怎么下手
  • ¥15 做一个关于单片机的比较难的代码,然后搞一个PPT进行解释
  • ¥15 python提取.csv文件中的链接会经常出现爬取失败
  • ¥15 数据结构中的数组地址问题
  • ¥15 maya的mel里,怎样先选择模型A,然后利用mel脚本自动选择有相同名字的模型B呢。
  • ¥15 Python题,根本不会啊
  • ¥15 会会信号与系统和python的来
  • ¥15 关于#python#的问题