HibernateTemplate里執(zhí)行SQL(非Select和Select)語句
下面將為您介紹在HibernateTemplate里執(zhí)行的兩種SQL語句,一種執(zhí)行非Select語句的情況,以及一種執(zhí)行Select語句的情況,供您參考,希望對(duì)您有所啟迪。
如下所示只能執(zhí)行非Select語句;
public static void executeSQL(HibernateTemplate hibernateTemplate,
String sql)
{
final String tempsql = sql;
hibernateTemplate.execute(new HibernateCallback()
{
public Object doInHibernate(Session session)
throws HibernateException
{
session.createQuery(tempsql).executeUpdate();
return null;
}
});
}
若要執(zhí)行Select則用session.createQuery(tempsql).list();
此處final String tempsql = sql;必須為final 表示tempsql不可以修改;#p#
內(nèi)聯(lián)類的要求;
public Object doInHibernate(Session session)返回Object等于hibernateTemplate.execute(new HibernateCallback()的返回,可以通過查看源代碼看的出來;
下面是執(zhí)行select語句的情況:
return (List)hibernateTemplate.execute(new HibernateCallback()
{
public Object doInHibernate(Session session)
throws HibernateException
{
List list=session.createQuery(tempsql).list();
return list;
}
});
【編輯推薦】
SQL中select語句返回多條記錄給變量賦值的處理