我有这个代码
System.out.println("Executing Select Query");
Query query = session.createQuery("from Student where name=:name");
query.setParameter("name", "Raj");
List list = query.list();
Iterator it = list.iterator();
while (it.hasNext()) {
Student stud = (Student) it.next();
System.out.println(stud.getName());
System.out.println(stud.getStandard());
}
System.out.println("Executing Update");
Transaction tx1 = session.beginTransaction();
Query queryupdate = session
.createQuery("update Student set standard = :standard where name = :name");
queryupdate.setParameter("name", "Raj");
queryupdate.setParameter("standard", "Third Standard");
int result = queryupdate.executeUpdate();
tx1.commit();
System.out.println("Student record updated " + result);
在下面 select query (Query query = session.createQuery("from Student where name=:name"));
上一行是从数据库中选择值。
Underupdate query Query queryupdate = session .createQuery("update Student set standard = :standard where name = :name");
不是在数据库中执行更新,而是queryupdate.executeUpdate();
在更新数据库。
所以我的问题是session.createQuery();
方法如何在两个查询中以不同的方式工作。请逐行向我解释以上程序的执行。
所以我的问题是session.createQuery(); 方法在两个查询中的工作方式不同
否。它的工作方式没有不同。
对于您select
和update
查询session.createQuery(java.lang.String); 返回类型的实例Query
对于给定的HQL查询字符串,请记住它不会触发任何查询既不select
也不是update
。
语句query.list()和queryupdate.executeUpdate()执行查询,并分别以list和int返回结果。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句