菜鸟求援!!!!急!

我做的是hibernate的HQL,出现了错误,请指教:

这是代码:

【1】.这是Employee类的定义:

package qau.edu.ren;

public class Employee {

private int no ;
private String name ;
private float salary ;

private Department dept ;

public int getNo() {
return no;
}

public void setNo(int no) {
this.no = no;
}

public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}

public float getSalary() {
return salary;
}

public void setSalary(float salary) {
this.salary = salary;
}

public Department getDept() {
return dept;
}

public void setDept(Department dept) {
this.dept = dept;
}

}

【2】.这是Department类的定义;

package qau.edu.ren;

import java.util.HashSet;
import java.util.Set;

public class Department {

private int no ;
private String name ;

private Set<Employee> employees = new HashSet<Employee>();

public int getNo() {
return no;
}

public void setNo(int no) {
this.no = no;
}

public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}

public Set<Employee> getEmployees() {
return employees;
}

public void setEmployees(Set<Employee> employees) {
this.employees = employees;
}}

【3】.下面是.cfg.xml配置文件;

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">

<hibernate-configuration>

<session-factory name="foo">

<!-- 配置SQL是否在控制台进行打印 -->

<property name="show_sql">true</property>

<!-- 配置SQL是否在输出的时候进行格式化 -->

<property name="format_sql">true</property>

<!-- 配置连接数据库的信息 -->

<property name="hibernate.connection.driver_class">oracle.jdbc.driver.OracleDriver</property>
<property name="hibernate.connection.url">jdbc:oracle:thin:@localhost:1521:orcl</property>
<property name="hibernate.connection.username">scott</property>
<property name="hibernate.connection.password">tiger</property>

<!-- 配置生成数据表的方式 -->

<property name="hbm2ddl.auto">update</property>

<!-- 配置数据库方言 -->

<property name="hibernate.dialect">org.hibernate.dialect.Oracle10gDialect</property>

<!-- 配置关系映射文件加载的路径 -->
<!-- <mapping resource="qau/edu/hibernate/OneToMany/Customer.hbm.xml" />
<mapping resource="qau/edu/hibernate/OneToMany/Order.hbm.xml" /> <mapping
resource="qau/edu/One2One/foreign/Manager.hbm.xml" /> <mapping resource="qau/edu/One2One/foreign/Department.hbm.xml"
/> -->

<mapping resource="qau/edu/ren/Employee.hbm.xml" />
<mapping resource="qau/edu/ren/Department.hbm.xml" />

</session-factory>

</hibernate-configuration>

【4】.这是.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="qau.edu.ren.Department" table="REN_DEPARTMENT">

<id name="no" type="int">
<column name="DEPT_ID" />
<generator class="native" />
</id>

<property name="name" type="java.lang.String">
<column name="NAME" />
</property>

<set name="employees" table="REN_EMPLOYEE" inverse="true" >
<key>
<column name="DEPT_ID" />
</key>
<one-to-many class="qau.edu.ren.Employee" />
</set>

</class>
</hibernate-mapping>

<?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="qau.edu.ren.Employee" table="REN_EMPLOYEE">

<id name="no" type="int">
<column name="EMP_ID" />
<generator class="native" />
</id>

<property name="name" type="java.lang.String">
<column name="NAME" />
</property>

<property name="salary" type="float">
<column name="SALARY" />
</property>

<many-to-one name="dept" class="qau.edu.ren.Department" >
<column name="DEPT_ID" />
</many-to-one>

</class>

</hibernate-mapping>

【5】.这是Test测试类;

package qau.edu.ren;

import java.util.List;

import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;

public class Test {

public static void main(String[] args) {

Session session = new Configuration().configure().buildSessionFactory()
.openSession();// 获取Session;
Transaction tr = session.beginTransaction();// 开始事务;

// Employee emp = (Employee) session.get(Employee.class, 7369);
//
// Department dept = (Department) session.get(Department.class, 30);
//
// System.out.println(dept.getEmployees().size());

String hql ="FROM REN_EMPLOYEE e WHERE e.salary > ? and e.name like ?";

Query query = session.createQuery(hql);

query.setFloat(0,6000)
.setString(1, "%A%");

List<Employee> employees = query.list();

System.out.println(employees);
}
}

【6】.这是提示的异常,但是就是没有解决;(我是用的Oracle 11g 和plsqldev界面工具)

log4j:WARN No appenders could be found for logger (org.hibernate.cfg.Environment).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.
Exception in thread "main" org.hibernate.hql.ast.QuerySyntaxException: REN_EMPLOYEE is not mapped [FROM REN_EMPLOYEE e WHERE e.salary > ? and e.name like ?]
at org.hibernate.hql.ast.util.SessionFactoryHelper.requireClassPersister(SessionFactoryHelper.java:181)
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:314)
at org.hibernate.hql.antlr.HqlSqlBaseWalker.fromElement(HqlSqlBaseWalker.java:3355)
at org.hibernate.hql.antlr.HqlSqlBaseWalker.fromElementList(HqlSqlBaseWalker.java:3239)
at org.hibernate.hql.antlr.HqlSqlBaseWalker.fromClause(HqlSqlBaseWalker.java:726)
at org.hibernate.hql.antlr.HqlSqlBaseWalker.query(HqlSqlBaseWalker.java:577)
at org.hibernate.hql.antlr.HqlSqlBaseWalker.selectStatement(HqlSqlBaseWalker.java:294)
at org.hibernate.hql.antlr.HqlSqlBaseWalker.statement(HqlSqlBaseWalker.java:237)
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:98)
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:1760)
at qau.edu.ren.Test.main(Test.java:26)

时间: 2024-10-09 02:01:18

菜鸟求援!!!!急!的相关文章

Android中实现图片点击跳转,菜鸟在线等 急求助

============问题描述============ 我想做一个点击图片然后跳转到其他界面的效果, 也就是实现图片点击事件  但是我不知道怎么监听点击事件 求助 ============解决方案1============ ImageView给个attr: android:id="@+id/image" android:clickable="true" 然后Activity实现View.OnClickListener接口,并实现onClick()方法,然后根据id

菜鸟的成长---第一个项目的完成

10月,工作后的第二个月.之前看到过一些大神的文章,里面有提到,最好每个月都写一篇文章,做一些记录.现阶段的我没有太多技术上和经验上的积累,那就暂且记录一下工作上的一些感悟吧,坚持下去,慢慢将越来越多的技术知识嵌入到每个月的文章中. 放完国庆回来就开始做项目,这是第一个真正意义上的项目.项目规模不算很大,开发周期为15天,一开始先是从经理那边拿到项目需求书,看了一遍,都没看出个所以然.慢慢地和经理讨论方案后才有了些思路,基于公司现有的一些DEMO进行修改,对细节方面进行一下修改即可.我负责的是a

给重回正路的大二学生:戒急戒躁中前行

[CSDN私信] 老师,您好,我今年大二了,我对我的处境感到迷茫,虽说我有加入实验室,接触了C#,js,htm,ajax等语言,但我只懂一点点,感觉没有学到什么,且对计算机没什么兴趣,只是不想毕业学不到什么,找不到工作,才加入的!希望您能够在学业与人生道路上给我一些建议! [回复1] 能否给我补充一些信息,你对什么感兴趣?大学毕业 后,你期望自己是什么样的? 如果私信中字数限制不够写,给我发Email: [email protected] [邮件] 恩,怎么说呢?计算机对我来说事实上是有点陌生的

&lt;转&gt;学习iOS开发的建议:如何从菜鸟到专家

本文转自:http://www.cnblogs.com/YouXianMing/p/3631577.html 文章原地址:http://mobile.tutsplus.com/tutorials/iphone/ios-quick-tip-from-novice-to-expert/ iOS Quick Tip: From Novice to Expert Bart Jacobs on Jul 29th 2013 with 5 comments Even though it's possible

菜鸟学SSH(十四)——Spring容器AOP的实现原理——动态代理

之前写了一篇关于IOC的博客--<Spring容器IOC解析及简单实现>,今天再来聊聊AOP.大家都知道Spring的两大特性是IOC和AOP. IOC负责将对象动态的注入到容器,从而达到一种需要谁就注入谁,什么时候需要就什么时候注入的效果,可谓是招之则来,挥之则去.想想都觉得爽,如果现实生活中也有这本事那就爽歪歪了,至于有多爽,各位自己脑补吧:而AOP呢,它实现的就是容器的另一大好处了,就是可以让容器中的对象都享有容器中的公共服务.那么容器是怎么做到的呢?它怎么就能让在它里面的对象自动拥有它

Java之美[从菜鸟到高手演变]之设计模式(zz)

http://blog.csdn.net/zhangerqing/article/details/8194653 设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结.使用设计模式是为了可重用代码.让代码更容易被他人理解.保证代码可靠性. 毫无疑问,设计模式于己于他人于系统都是多赢的,设计模式使代码编制真正工程化,设计模式是软件工程的基石,如同大厦的一块块砖石一样.项目中合理的运用设计模式可以完美的解决很多问题,每种模式在现在中都有相应的原理

一个Android菜鸟“面霸”的面试经历,如何少走弯路多加薪!

作为程序员,尤其是菜鸟程序员,如何成为一个"面霸"征战沙场,少走弯路,升职加薪,当上CTO,迎娶白富美! 今天是我入职一个创业公司的第二天.由于公司今天才把自己用的电脑买回来,只好今天在做着每一个技术人员入职第一天常做的事:安装相关开发软件,配置开发环境. 在安装软件的过程中,由于下载最新版的android studio比较缓慢,只好在下载过程中随便翻翻.然后,看到一个开发群里,一位朋友还在聊面试的事,他在那里说,今天又没有面试通知.听了之后,感慨万千,这样的感受我也有过很多次. 至于

让编程菜鸟爱上iPhone开发1-Swift+iOS8版

对iPhone开发感兴趣的初学童鞋们奉上一篇认可度较高的iPhone开发教程,助你轻轻松松提高自己的职业修养. 提醒:本文是系列教程中的开篇,不适合程序猿出身的童鞋!目的只是让初学者.产品策划,设计或管理人员了解iPhone开发的基础知识. 主要素材和示例项目来源:Ray Wenderlich store 特别说明:不适合程序猿出身的童鞋!目的是让初学者.产品策划,设计或管理人员了解iPhone开发的基础知识. 适合看本系列教程的对象: 1.从未学过编程,或者对Swift语言一无所知,但要懂一些

马云的利他思想和菜鸟1300亿的商业布局

神秘的北纬30° 金字塔.中东北海.百慕大三角.雅鲁藏布大峡谷.喜马拉雅山.神农架--,诸多百思不得其解的秘密都存在于这条线上. 浙江桐庐,就位于北纬30°,这里的农民将创造一个伟大的奇迹. 如果从历史的天空打量,1993年是一个里程碑. 那年春天,上海市浦东新区正式成立,进出口贸易红红火火.也是这一年,浙江省经过工商注册的个体工商户已有153.2万户之多,注册资金40亿元,其中相当多的工商户是做外贸生意. 为了不耽误货物出口,杭州外贸公司的报关单需要第二天送达上海,可邮政快递最快要三天. 咋整