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
posted on 2011-04-28 21:27 archie2010 阅读(1931) 评论(0) 编辑 收藏 举报