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页面中打印两个类的东西
提前感谢。
`
答案 0 :(得分: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();
修改强>
从查询中删除;
。
答案 1 :(得分:0)
您正在使用setParameter
方法将值放入命名参数中,但您并未将任何命名参数放入查询字符串中。你使用&#34;:&#34;语法来做到这一点。
我无法弄清楚你的查询是什么,所以我不知道你是否真的想要命名参数。从您的结果转换器猜测,我想您需要一个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);
答案 2 :(得分:0)
//我们如何在jdbc中编写连接查询与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);
%>