• JPA查询语言JPQL


          JPQL是一种与数据库无关的,基于实体(entity-based)的查询语言

    使用SQL,你可以直接查询数据库中表的字段;使用JPQL,你可以查找实体的属性。

          一个JPQL语句的各个组成部分都是针对实体或者实体的属性进行的操作

    根本不会用到一个实体所映射的数据库表和字段。下面是你可以创建紧最基本的JPQL语句:

    SELECT u FROM User

        即为  查询从数据库返回所有的User实例

    使用JPQL语言的CRUD操作

    /**
    *
    JPQL测试
    查询语句测试
    *
    @author archie2010
    *
    * since 下午10:21:37
    */
    public class JQLTest {

    /**
    * 获取单个的对象
    */
    public static void findUserByJql(){
    EntityManagerFactory factory
    = Persistence.createEntityManagerFactory("jpaTest");
    EntityManager em
    = factory.createEntityManager();

    Query query
    = (Query)em.createQuery("select u from User u where u.id = ?1");
    query.setParameter(
    1,2);//第一个参数及其值

    User user
    = (User)query.getSingleResult();
    System.out.println(user.getUserName());

    em.close();
    factory.close();
    }
    /**
    * 查询所有
    */
    @SuppressWarnings(
    "unchecked")
    public static void findAll(){
    EntityManagerFactory factory
    = Persistence.createEntityManagerFactory("jpaTest");
    EntityManager em
    = factory.createEntityManager();

    Query query
    = (Query)em.createQuery("select u from User u");

    List
    <User> list = query.getResultList();
    System.out.println(
    "查询所有---------------");
    for(User u:list){
    System.out.println(u.getUserName());
    }
    }
    /**
    * 更新
    */
    public static void updateByJql(){
    EntityManagerFactory factory
    = Persistence.createEntityManagerFactory("jpaTest");
    EntityManager em
    = factory.createEntityManager();

    em.getTransaction().begin();
    Query query
    = (Query)em.createQuery("update User u set u.userName = ?1 where u.id = ?2");
    query.setParameter(
    1,"jiejie");
    query.setParameter(
    2,2);

    query.executeUpdate();
    em.getTransaction().commit();
    em.close();
    factory.close();
    }
    /**
    * 删除
    */
    public static void deleteByJql(){
    EntityManagerFactory factory
    = Persistence.createEntityManagerFactory("jpaTest");
    EntityManager em
    = factory.createEntityManager();

    em.getTransaction().begin();
    Query query
    = em.createQuery("delete from User u where u.id = ?1");
    query.setParameter(
    1, 1);
    query.executeUpdate();
    em.getTransaction().commit();

    em.close();
    factory.close();
    }
    /**
    * JPQL测试
    *
    @param args
    */
    public static void main(String[] args) {
    findUserByJql();
    findAll();
    updateByJql();
    deleteByJql();
    }
    }
    by archie
  • 相关阅读:
    Java并发 --对象的共享
    建立一个二叉查找树
    Tomcat 服务优化
    Mina框架(实战详解)
    ES 查询实战
    IEDA安装配置
    Redis操作以及连接异常
    CyclicBarrier[进程同步辅助类]实现进程间同步
    Linux下端口占用解决方法
    物化视图插入记录,手动刷新问题
  • 原文地址:https://www.cnblogs.com/archie2010/p/2032203.html
Copyright © 2020-2023  润新知