动态查询:
package com.atsico.pojo01;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.Accessors;
import javax.persistence.*;
@Data
@NoArgsConstructor
@AllArgsConstructor
@Accessors(chain = true)
@Entity
@Table(name = “student”)
public class Student {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private int id;
private String name;
private int age;
private String classname;
}
<?xml version="1.0" encoding="UTF-8"?> org.eclipse.persistence.jpa.PersistenceProvider com.atsico.pojo01.Student <properties>
<!-- 连接数据库的基本信息 -->
<property name="javax.persistence.jdbc.driver"
value="com.mysql.cj.jdbc.Driver"/>
<property name="javax.persistence.jdbc.url"
value="jdbc:mysql://localhost:3306/jpadb?useSSL=false&serverTimezone=Asia/Shanghai"/>
<property name="javax.persistence.jdbc.user" value="root"/>
<property name="javax.persistence.jdbc.password"
value="root"/>
<property name="eclipselink.logging.level" value="all"/>
<property name="eclipselink.ddl-generation"
value="create-or-extend-tables"/>
<property name="eclipselink.show_sql" value="true"/>
</properties>
</persistence-unit>
package com.atsico.service;
import com.atsico.pojo01.Student;
import org.junit.Test;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.Query;
import java.util.List;
public class Jpa_Jpql_Test {
@Test/*动态查询*/
public void test_select_01() {
EntityManagerFactory emf =
Persistence.createEntityManagerFactory("myPersistUnit");
EntityManager em = emf.createEntityManager();
/*动态查询*/
Query q = em.createQuery("select s from Student s");
@SuppressWarnings("unchecked")
List<Student> resultList = q.getResultList();
for (Student stu : resultList) {
System.out.println(stu);
}
}
}
动态查询结果:
Student(id=1, name=Sico, age=11, classname=102)
Student(id=2, name=Tomy, age=10, classname=107)
Student(id=3, name=Lily, age=13, classname=108)
Student(id=4, name=Hong, age=12, classname=101)
/****************************************************************************************/
静态查询:
package com.atsico.pojo01;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.Accessors;
import javax.persistence.*;
@Data
@NoArgsConstructor
@AllArgsConstructor
@Accessors(chain = true)
@Entity
@Table(name = “student”)
@NamedQuery(name = “find Student”, query = "select s from Student s ")
public class Student {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private int id;
private String name;
private int age;
private String classname;
}
<?xml version="1.0" encoding="UTF-8"?> org.eclipse.persistence.jpa.PersistenceProvider <class>com.atsico.pojo01.Student</class>
<properties>
<!-- 连接数据库的基本信息 -->
<property name="javax.persistence.jdbc.driver"
value="com.mysql.cj.jdbc.Driver"/>
<property name="javax.persistence.jdbc.url"
value="jdbc:mysql://localhost:3306/jpadb?useSSL=false&serverTimezone=Asia/Shanghai"/>
<property name="javax.persistence.jdbc.user" value="root"/>
<property name="javax.persistence.jdbc.password"
value="root"/>
<property name="eclipselink.logging.level" value="all"/>
<property name="eclipselink.ddl-generation"
value="create-or-extend-tables"/>
<property name="eclipselink.show_sql" value="true"/>
</properties>
</persistence-unit>
package com.atsico.service;
import com.atsico.pojo01.Student;
import org.junit.Test;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import javax.persistence.Query;
import java.util.List;
public class Jpa_Jpql_Test {
@Test/*静态态查询*/
public void test_select_02() {
EntityManagerFactory emf =
Persistence.createEntityManagerFactory("myPersistUnit");
EntityManager em = emf.createEntityManager();
/*动态查询*/
Query q = em.createNamedQuery("find Student");
@SuppressWarnings("unchecked")
List<Student> resultList = q.getResultList();
for (Student stu : resultList) {
System.out.println(stu);
}
}
}
静态查询结果:
Student(id=1, name=Sico, age=11, classname=102)
Student(id=2, name=Tomy, age=10, classname=107)
Student(id=3, name=Lily, age=13, classname=108)
Student(id=4, name=Hong, age=12, classname=101)