HQL查询无法正常工作?

TruePS

我有这个代码

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(); 方法在两个查询中的工作方式不同

否。它的工作方式没有不同。

  1. 对于您selectupdate查询session.createQuery(java.lang.String); 返回类型的实例Query对于给定的HQL查询字符串,请记住它不会触发任何查询既不select也不是update

  2. 语句query.list()queryupdate.executeUpdate()执行查询,并分别以list和int返回结果。

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章