关于Hibernate映射

Razer 2010-07-14 08:51:58
我的错误提示为
org.hibernate.hql.ast.QuerySyntaxException: LIBRARY is not mapped [select l from LIBRARY as l order by l.id]
at org.hibernate.hql.ast.util.SessionFactoryHelper.requireClassPersister(SessionFactoryHelper.java:181)

数据库的表叫LIBRARY,有三个字段ID,TITLE,CONTENT,其中ID为主键
关键代码为
model.hbm.xml
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

<hibernate-mapping>
<class name="hbm.DVDItem" table="LIBRARY">
<id name="id" type="int" column="ID" >
<generator class="native"/>
</id>
<property name="title" column="TITLE"/>
<property name="content" column="CONTENT" />
</class>
</hibernate-mapping>


javabean放在hbm包内
package hbm;


public class DVDItem {
private int id;
private String title;
private String content;

public DVDItem(){}

public int getId() {
return id;
}

public void setId(int id) {
this.id = id;
}

public String getTitle() {
return title;
}

public void setTitle(String title) {
this.title = title;
}

public String getContent() {
return content;
}

public void setContent(String content) {
this.content = content;
}

}


在代码中用到了查询语句为
select l from LIBRARY as l order by l.id

不知道哪映射错了,麻烦大家帮我看看 谢谢
...全文
64 10 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
饭饭 2010-07-14
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 closewbq 的回复:]
HQL
在form后面跟的是类名。不是表名
[/Quote]


切中要害....
Razer 2010-07-14
  • 打赏
  • 举报
回复
谢谢大家 我是初学者 犯了这个错误
JerryZhou_ 2010-07-14
  • 打赏
  • 举报
回复
LIBRARY is not mapped [select l from LIBRARY as l order by l.id]
很明显 这个类LIBRARY 没有被映射
还有就是在HQL语句里面 用的不是数据库表的名字 而是与之相对应的Entity,属性也是 也应该是Entity的属性 不是数据库列的名字
kString 2010-07-14
  • 打赏
  • 举报
回复
hql用的是对象不是数据库表
折腾的生活 2010-07-14
  • 打赏
  • 举报
回复
你用的session.createQuery() 就得用DVDItem---------------------hql
你用的session.createSQLQuery()就得用数据库中表名了
亲努力啊 2010-07-14
  • 打赏
  • 举报
回复

<hibernate-mapping>
<class name="hbm.DVDItem" table="LIBRARY">
<id name="id" type="int" column="ID" >
<generator class="native"/>
</id>
<property name="title" column="TITLE"/>
<property name="content" column="CONTENT" />
</class>
</hibernate-mapping>



<class name="hbm.DVDItem" table="LIBRARY">
<id name="id" type="java.lang.Long">
<column name="ID" precision="22" scale="0" />
<generator class="native" />
</id>
<property name="title" type="java.lang.String">
<column name="TITLE" />
</property>
<property name="content" type="java.lang.String">
<column name="CONTENT" />
</property>
</class>
closewbq 2010-07-14
  • 打赏
  • 举报
回复
HQL
在form后面跟的是类名。不是表名
fei381895649fei 2010-07-14
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 soli11722984 的回复:]
from DVDItem as l order by l.id
[/Quote]

2楼的人就说对了啊!!!你去试试吧!!!
soli11722984 2010-07-14
  • 打赏
  • 举报
回复
from DVDItem as l order by l.id
亲努力啊 2010-07-14
  • 打赏
  • 举报
回复
DVDItem 用这个表名

67,550

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧