java – org.hibernate.hql.ast.QuerySyntaxException:TABLE NA
发布时间:2020-12-14 05:27:44 所属栏目:Java 来源:网络整理
导读:我有两个模型,Item和ShopSection.他们有多对多的关系. @Entity(name = "item")public class Item extends Model{ @ManyToMany(cascade = CascadeType.PERSIST) public SetShopSection sections;}@Entity(name = "shop_section")public class ShopSection ext
我有两个模型,Item和ShopSection.他们有多对多的关系.
@Entity(name = "item") public class Item extends Model { @ManyToMany(cascade = CascadeType.PERSIST) public Set<ShopSection> sections; } @Entity(name = "shop_section") public class ShopSection extends Model { public List<Item> findActiveItems(int page,int length) { return Item.find("select distinct i from Item i join i.sections as s where s.id = ?",id).fetch(page,length); } } findActiveItems是在一个部分中查找项目,但是我得到这个错误: org.hibernate.hql.ast.QuerySyntaxException: Item is not mapped [select distinct i from Item i join i.sections as s where s.id = ?] at org.hibernate.hql.ast.util.SessionFactoryHelper.requireClassPersister(SessionFactoryHelper.java:180) at org.hibernate.hql.ast.tree.FromElementFactory.addFromElement(FromElementFactory.java:111) at org.hibernate.hql.ast.tree.FromClause.addFromElement(FromClause.java:93) at org.hibernate.hql.ast.HqlSqlWalker.createFromElement(HqlSqlWalker.java:322) at org.hibernate.hql.antlr.HqlSqlBaseWalker.fromElement(HqlSqlBaseWalker.java:3441) at org.hibernate.hql.antlr.HqlSqlBaseWalker.fromElementList(HqlSqlBaseWalker.java:3325) at org.hibernate.hql.antlr.HqlSqlBaseWalker.fromClause(HqlSqlBaseWalker.java:733) at org.hibernate.hql.antlr.HqlSqlBaseWalker.query(HqlSqlBaseWalker.java:584) at org.hibernate.hql.antlr.HqlSqlBaseWalker.selectStatement(HqlSqlBaseWalker.java:301) at org.hibernate.hql.antlr.HqlSqlBaseWalker.statement(HqlSqlBaseWalker.java:244) at org.hibernate.hql.ast.QueryTranslatorImpl.analyze(QueryTranslatorImpl.java:254) at org.hibernate.hql.ast.QueryTranslatorImpl.doCompile(QueryTranslatorImpl.java:185) at org.hibernate.hql.ast.QueryTranslatorImpl.compile(QueryTranslatorImpl.java:136) at org.hibernate.engine.query.HQLQueryPlan.<init>(HQLQueryPlan.java:101) at org.hibernate.engine.query.HQLQueryPlan.<init>(HQLQueryPlan.java:80) at org.hibernate.engine.query.QueryPlanCache.getHQLQueryPlan(QueryPlanCache.java:124) at org.hibernate.impl.AbstractSessionImpl.getHQLQueryPlan(AbstractSessionImpl.java:156) at org.hibernate.impl.AbstractSessionImpl.createQuery(AbstractSessionImpl.java:135) at org.hibernate.impl.SessionImpl.createQuery(SessionImpl.java:1770) at org.hibernate.ejb.AbstractEntityManagerImpl.createQuery(AbstractEntityManagerImpl.java:272) ... 8 more 我究竟做错了什么? 解决方法
您需要添加如下的@Table注释:
@Entity @Table(name = "item") public class Item extends Model { @ManyToMany(cascade = CascadeType.PERSIST) public Set<ShopSection> sections; } @Entity @Table(name = "shop_section") public class ShopSection extends Model { public List<Item> findActiveItems(int page,length); } } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- java – 使用duplicate-finder插件重复资源错误
- java – 我可以使用Apache Pivot而不是Swing吗?
- java – OSS实施Google应用引擎?
- java – 为什么我的SOCKS代理代码抛出SocketException:来自
- java – CheckStyle模块“NeedBraces”可以使用嵌套的if /
- java – 为什么接口根据类文件格式扩展Object?
- 使用Java 8 Optional for String of List作为输出
- java – 如何将要同步的电子邮件ID传递到android中创建事件
- jsf – 与Java Facelets有什么区别?
- java – 单击命令图标后如何显示命令的下拉菜单?