0
List<AddHotelBean> list=new ArrayList<AddHotelBean>();
List<HotelFacilities> list1=new ArrayList<HotelFacilities>();
public String execute(){

    Configuration cfg=new Configuration();
    cfg.configure();
    SessionFactory sf=cfg.buildSessionFactory();
    Session session=    sf.openSession();

    SQLQuery q=session.createSQLQuery("select d.name,d.country,f.monday,f.tuesday from hotel.hoteldetails1 d , hotel.hotelfacilities1 f where d.hotelid=f.hotelid;");


    q.addScalar("name", StandardBasicTypes.STRING);
    q.addScalar("country", StandardBasicTypes.STRING);
    q.addScalar("monday", StandardBasicTypes.STRING);
    q.addScalar("tuesday", StandardBasicTypes.STRING);

    q.setResultTransformer(Transformers.aliasToBean(HotelFacilities.class));

    List<HotelFacilities> l=q.list();

    for(HotelFacilities a:l) {
        a.getMonday();
        a.getTuesday();
        list1.add(a);
    }
org.hibernate.QueryParameterException: could not locate named parameter [hotelid]

我得到这个例外请任何人帮助我

实际上我的疑问是我正在使用两个 pojo 类,但我的 Transformers.aliasToBean 只是一个类,它实际上需要两个类的东西才能在我的输出 jsp 页面中打印

提前致谢。

`

4

3 回答 3

0

我认为您对参数感到困惑。setParameter()当您想在查询中传递一些值时调用。

SQLQuery q=session.createSQLQuery("select d.name from hotel.hoteldetails1 d where d.hotelid=:hotelidd");
q.setParameter("hotelid", 1);

您不需要查询中的任何值,因此您根本不需要调用 setParamert。尝试这个

SQLQuery q=session.createSQLQuery("SELECT d.name, d.country, f.monday, f.tuesday FROM hoteldetails1 d JOIN hotelfacilities1 f ON d.hotelid=f.hotelid");
q.setResultTransformer(Transformers.aliasToBean(HotelFacilities.class));
List<HotelFacilities> l=q.list();

编辑

;从查询中删除。

于 2014-07-20T08:34:21.087 回答
0

您正在使用该setParameter方法将值放入命名参数中,但您没有将任何命名参数放入查询字符串中。您使用“:”语法来做到这一点。

我不知道你的查询是什么,所以我不知道你是否真的想要命名参数。从你的结果转换器猜测,我认为你想要一个HotelFacilities对象列表。

此外,您使用了一些非常笨拙的语法,我将在此示例中替换它。

from HotelFacilities f
join HotelDetails d
where d.name = :name
  and d.country = :country
  and f.monday = :monday
  and f.tuesday = :tuesday

此查询返回星期一属性和星期二属性与命名参数匹配的所有 HotelFacilities,并且匹配的 HotelDetails 与提供的名称和国家/地区属性匹配。您不必加入 HotelID,因为(我假设)已经在您的映射中处理了。

要在您的 java 代码中设置这些命名参数,请使用正确的类型化方法,在本例中为setString.

q.setString("name", detailsName);
q.setString("country", detailsCountry);
q.setString("monday", facilitiesMonday);
q.setString("tuesday", facilitiesTuesday);
于 2014-07-20T08:37:50.307 回答
0

//我们在jdbc中写join查询的方式和hibernate一样

//local level
ArrayList<Object[]> data = new ArrayList<Object[]>();
Map request;


//method level
SQLQuery q=session.createSQLQuery("select  h.roomid as roomid, h.phone1 as     phone1,h.phone2 as phone2,r.type as type,r.nrooms as nrooms from hoteldetails1 h,roomdetails1 r where h.roomid=r.roomid ");

    System.out.println("after query");
    //q.setParameter(0,roomid);


    q.addScalar("roomid",StandardBasicTypes.INTEGER);
    q.addScalar("phone1",StandardBasicTypes.STRING);
    q.addScalar("phone2",StandardBasicTypes.STRING);
    q.addScalar("type",StandardBasicTypes.STRING);
    q.addScalar("nrooms",StandardBasicTypes.STRING);

    List<Object[]> l=q.list();

    System.out.println("b4 for loop");
    for(Object[] obj:l){



        data.add(obj);
        request.put("l",data);

    }

  return "success";


 /*
 in the jsp page how to retrive the output is given below
*/

//in jsp page code is like this
<%


List<Object[]> l =(List) request.getAttribute("l");



%>

 <table border=1>
 <tr>
 <th>roomid</th>
 <th>phone1</th>
 <th>phone2</th>
 <th>type</th>
 <th>rooms</th>

 </tr>  
 <%
  for(Object[] obj:l){


  int i=(Integer)obj[0];
  String j=(String)obj[1];
  String k=(String)obj[2];
  String r=(String)obj[3];
  String m=(String)obj[4];
  out.println(obj[0] +"   "+i);
  out.println(obj[1] +"   "+j);
  out.println(obj[2] +"   "+k);
  out.println(obj[3] +"   "+r);
  out.println(obj[4] +"   "+m); 

    %>
于 2014-09-09T06:43:29.980 回答