当前位置:Gxlcms > 数据库问题 > Jpa实现数据库的CRUD

Jpa实现数据库的CRUD

时间:2021-07-01 10:21:17 帮助过:22人阅读

    3...创建 配置文件          员(数据源)工(工程类对象)是(事物)爹(dao 扫描器)

    4... 创建实体类  

    5... 创建dao 接口  继承 JapRespository

2....五种查询方式

(1) crud

    添加/修改 数据 save 方法

?     删除数据 delete 方法

?     查询 :findOne.  getOne 方法

    ? 查询全部 findAll() 方法

?     findAll(Pageable pageaable) 返回Page对象 进行分页  排序

(2) 在springDataJpa框架使用Jpql 查询 

    a: 在dao 接口中定义一个方法 使用方法的参数设置jpql的参数 并且使用方法的返回值接受查询的结果

?     b: 在方法上添加一个注解Qquery

?     c 在注解中编写jpql

?     d 测试

(3)使用原生的Sql语句

    1 dao中 定义一个方法

?     2 在方法中添加@Query注解

?     3 在注解中 添加 原生的sql 语句 添加一个属性 nativeQuery=true

?     4 测试

(4)方法命名规则查询

      通过一定的规则 定义一个方法 框架本省就可以根据方法名生成一个SQL语句进行查询

  ? 规则:

?     1 使用findBy开头

?     2 查询某个字段 findBy后跟实体类的属性的名称

?     3 如果有多个条件 就在方法后加And+实体类的属性名

?     4 方法的参数 对应查询的定义

?     5 返回值根据返回的数据类型定义

    如果需要分页查询 在方法中添加一个参数Pageable 即可

5)使用Specification方式进行查询

       最强大的查询方式 除了原生的SQL 语句以外 最复杂的查询方式

   使用方式:

?     1 要在dao 继承JpaSeciFicationExection 接口

?     2 使用JpaSeciFicationExection 接口 中提供的方法进行查询

?     每个方法都需要使用Specification对象作为参数

 

具体实现:::

1...pom.xml 配置

技术图片
  1 <?xml version="1.0" encoding="UTF-8"?>
  2 <project xmlns="http://maven.apache.org/POM/4.0.0"
  3          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  5     <modelVersion>4.0.0</modelVersion>
  6 
  7     <groupId>com.wsc</groupId>
  8     <artifactId>springdatalpa01</artifactId>
  9     <version>1.0-SNAPSHOT</version>
 10 
 11 
 12     <properties>
 13         <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
 14         <maven.compiler.source>1.8</maven.compiler.source>
 15         <maven.compiler.target>1.8</maven.compiler.target>
 16         <spring.version>4.2.4.RELEASE</spring.version>
 17         <hibernate.version>5.0.7.Final</hibernate.version>
 18         <slf4j.version>1.6.6</slf4j.version>
 19         <log4j.version>1.2.12</log4j.version>
 20         <c3p0.version>0.9.1.2</c3p0.version>
 21         <mysql.version>5.1.6</mysql.version>
 22     </properties>
 23     <dependencies>
 24         <dependency>
 25             <groupId>junit</groupId>
 26             <artifactId>junit</artifactId>
 27             <version>4.12</version>
 28             <scope>test</scope>
 29         </dependency>
 30         <!--spring start-->
 31         <dependency>
 32             <groupId>org.aspectj</groupId>
 33             <artifactId>aspectjweaver</artifactId>
 34             <version>1.6.8</version>
 35         </dependency>
 36         <dependency>
 37             <groupId>org.springframework</groupId>
 38             <artifactId>spring-aop</artifactId>
 39             <version>${spring.version}</version>
 40         </dependency>
 41         <dependency>
 42             <groupId>org.springframework</groupId>
 43             <artifactId>spring-context</artifactId>
 44             <version>${spring.version}</version>
 45         </dependency>
 46         <dependency>
 47             <groupId>org.springframework</groupId>
 48             <artifactId>spring-context-support</artifactId>
 49             <version>${spring.version}</version>
 50         </dependency>
 51         <dependency>
 52             <groupId>org.springframework</groupId>
 53             <artifactId>spring-orm</artifactId>
 54             <version>${spring.version}</version>
 55         </dependency>
 56         <dependency>
 57             <groupId>org.springframework</groupId>
 58             <artifactId>spring-beans</artifactId>
 59             <version>${spring.version}</version>
 60         </dependency>
 61         <dependency>
 62             <groupId>org.springframework</groupId>
 63             <artifactId>spring-core</artifactId>
 64             <version>${spring.version}</version>
 65         </dependency>
 66         <!--spring end-->
 67         <!--hibernate start-->
 68         <dependency>
 69             <groupId>org.hibernate</groupId>
 70             <artifactId>hibernate-core</artifactId>
 71             <version>${hibernate.version}</version>
 72         </dependency>
 73         <dependency>
 74             <groupId>org.hibernate</groupId>
 75             <artifactId>hibernate-entitymanager</artifactId>
 76             <version>${hibernate.version}</version>
 77         </dependency>
 78         <dependency>
 79             <groupId>org.hibernate</groupId>
 80             <artifactId>hibernate-validator</artifactId>
 81             <version>5.2.1.Final</version>
 82         </dependency>
 83         <!--hibernate end-->
 84         <dependency>
 85             <groupId>c3p0</groupId>
 86             <artifactId>c3p0</artifactId>
 87             <version>${c3p0.version}</version>
 88         </dependency>
 89         <dependency>
 90             <groupId>log4j</groupId>
 91             <artifactId>log4j</artifactId>
 92             <version>${log4j.version}</version>
 93         </dependency>
 94         <dependency>
 95             <groupId>org.slf4j</groupId>
 96             <artifactId>slf4j-api</artifactId>
 97             <version>${slf4j.version}</version>
 98         </dependency>
 99         <dependency>
100             <groupId>org.slf4j</groupId>
101             <artifactId>slf4j-log4j12</artifactId>
102             <version>${slf4j.version}</version>
103         </dependency>
104         <dependency>
105             <groupId>mysql</groupId>
106             <artifactId>mysql-connector-java</artifactId>
107             <version>${mysql.version}</version>
108         </dependency>
109         <dependency>
110             <groupId>org.springframework.data</groupId>
111             <artifactId>spring-data-jpa</artifactId>
112             <version>1.9.0.RELEASE</version>
113         </dependency>
114         <dependency>
115             <groupId>org.springframework</groupId>
116             <artifactId>spring-test</artifactId>
117             <version>4.2.4.RELEASE</version>
118         </dependency>
119         <dependency>
120             <groupId>javax.el</groupId>
121             <artifactId>javax.el-api</artifactId>
122             <version>2.2.4</version>
123         </dependency>
124         <dependency>
125             <groupId>org.glassfish.web</groupId>
126             <artifactId>javax.el</artifactId>
127             <version>2.2.4</version>
128         </dependency>
129     </dependencies>
130 </project>
pom.xml

2...applicationContext.xml

技术图片
 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <beans xmlns="http://www.springframework.org/schema/beans"
 3        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop"
 4        xmlns:context="http://www.springframework.org/schema/context"
 5        xmlns:jdbc="http://www.springframework.org/schema/jdbc" xmlns:tx="http://www.springframework.org/schema/tx"
 6        xmlns:jpa="http://www.springframework.org/schema/data/jpa" xmlns:task="http://www.springframework.org/schema/task"
 7        xsi:schemaLocation="
 8 http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
 9 http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd
10 http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
11 http://www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc.xsd
12 http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd
13 http://www.springframework.org/schema/data/jpa
14 http://www.springframework.org/schema/data/jpa/spring-jpa.xsd">
15     <!--1 dataSource-->
16     <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
17         <property name="password" value="wsc"></property>
18         <property name="user" value="root"></property>
19         <property name="jdbcUrl" value="jdbc:mysql://localhost:3306/shop?characterEncoding=utf-8"></property>
20         <property name="driverClass" value="com.mysql.jdbc.Driver"></property>
21     </bean>
22     <!--2 工厂类对象-->
23     <bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
24         <!--数据源-->
25         <property name="dataSource" ref="dataSource"></property>
26         <property name="packagesToScan" value="com.wsc.core.entity"></property>
27         <!--配置供应商适配器-->
28         <property name="jpaVendorAdapter">
29             <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter">
30                  <property name="showSql" value="true"></property>
31                  <property name="generateDdl" value="true"></property>
32                 <!--是否向控制台输出语句 update hibernate.hbm2ddl.auto-->
33                 <property name="database" value="MYSQL"></property>
34             </bean>
35         </property>
36     </bean>
37     <!--配置事物-->
38     <bean id="jpaTransactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
39         <property name="entityManagerFactory" ref="entityManagerFactory"></property>
40     </bean>
41     <tx:advice id="txAdvice" transaction-manager="jpaTransactionManager">
42         <tx:attributes>
43             <tx:method name="save*" propagation="REQUIRED"/>
44             <tx:method name="insert*" propagation="REQUIRED"/>
45             <tx:method name="update*" propagation="REQUIRED"/>
46             <tx:method name="delete*" propagation="REQUIRED"/>
47             <tx:method name="get*" read-only="true"/>
48             <tx:method name="find*" read-only="true"/>
49             <tx:method name="*" propagation="REQUIRED"/>
50         </tx:attributes>
51     </tx:advice>
52     <aop:config>
53         <aop:pointcut id="pointcut" expression="execution(* com.wsc.core.service.*.*(..)) "/>
54         <aop:advisor advice-ref="txAdvice" pointcut-ref="pointcut"></aop:advisor>
55     </aop:config>
56     <!--dao-->
57     <jpa:repositories base-package="com.wsc.core.dao"
58     transaction-manager-ref="jpaTransactionManager"
59     entity-manager-factory-ref="entityManagerFactory">
60     </jpa:repositories>
61 </beans>
applicationContext.xml

3.....实体类

技术图片
 1 package com.wsc.core.entity;
 2 
 3 import javax.persistence.*;
 4 
 5 /**
 6  * @version 1.0
 7  * @ClassName Account
 8  * @Description TODO
 9  * @Author WSC
10  * @Date 2019/8/16 11:31
11  **/
12 @Entity
13 @Table(name="ac_account")
14 public class Account {
15     @GeneratedValue(strategy= GenerationType.IDENTITY)
16     @Id
17     @Column(name="ac_id")
18     private int acId;
19     @Column(name="ac_address")
20     private String acAddress;
21     @Column(name="ac_name")
22     private String acName;
23     @Column(name="ac_age")
24     private int acAge;
25 
26     public int getAcId() {
27         return acId;
28     }
29 
30     public void setAcId(int acId) {
31         this.acId = acId;
32     }
33 
34     public String getAcAddress() {
35         return acAddress;
36     }
37 
38     public void setAcAddress(String acAddress) {
39         this.acAddress = acAddress;
40     }
41 
42     public String getAcName() {
43         return acName;
44     }
45 
46     public void setAcName(String acName) {
47         this.acName = acName;
48     }
49 
50     public int getAcAge() {
51         return acAge;
52     }
53 
54     public void setAcAge(int acAge) {
55         this.acAge = acAge;
56     }
57 
58     @Override
59     public String toString() {
60         return "Account{" +
61                 "acId=" + acId +
62                 ", acAddress=‘" + acAddress + ‘\‘‘ +
63                 ", acName=‘" + acName + ‘\‘‘ +
64                 ", acAge=" + acAge +
65                 ‘}‘;
66     }
67 }
实体类

4....dao

技术图片
 1 package com.wsc.core.dao;
 2 
 3 import com.wsc.core.entity.Account;
 4 import org.springframework.data.domain.Page;
 5 import org.springframework.data.domain.Pageable;
 6 import org.springframework.data.jpa.repository.JpaRepository;
 7 import org.springframework.data.jpa.repository.JpaSpecificationExecutor;
 8 import org.springframework.data.jpa.repository.Modifying;
 9 import org.springframework.data.jpa.repository.Query;
10 import org.springframework.transaction.annotation.Transactional;
11 
12 import java.util.List;
13 
14 //实现JpaRepository接口
15 public interface AccountDao extends JpaRepository<Account,Integer>, JpaSpecificationExecutor<Account> {
16     /**
17      * 查询全部
18      * @return
19      */
20     @Query("from Account ")
21     public List<Account> getFindAll();
22     /**
23      * 查询全部  分页
24      * @return
25      * @param pageable
26      */
27     @Query("from Account ")
28     public List<Account> getFindAllByPage(Pageable pageable);
29     /**
30      * 根据id查询
31      */
32     @Query("from Account where ac_id=?1")
33     public Account getFindById(Long ac_id);
34 
35     /**
36      *
37      * 模糊查询
38      */
39     @Query("from Account where acName like ?1 and acAddress like ?2")
40     public List<Account> findByName(String acName,String acAddress);
41 
42     /**
43      *  修改数据
44      */
45     @Modifying
46     @Transactional
47     @Query("update Account set acName=?1 where acId=?2")
48     public void change(String acName,Integer acId);
49 
50    // 原生SQL 语句查询
51     /**
52      * 原生SQL 语句查询
53      */
54     @Query(value = "select  * from ac_account WHERE ac_name LIKE ?" ,nativeQuery = true)
55     public List<Account> getAccount(String name);
56 
57     //方法命名规则查询
58     /**
59      *  根据id查询
60      */
61     public Account findAccountByAcId(Integer id);
62 
63     /**
64      *  模糊查询
65      * @param address
66      * @param name
67      * @return
68      */
69     public List<Account> findByAcAddressLikeAndAcNameLike(String address,String name);
70 
71     /**
72      * 分页查询
73      * @param name
74      * @param pageable
75      * @return
76      */
77     public Page<Account> findByAcNameLike(String name,Pageable pageable);
78 
79 
80  }
dao

5.....test

 test 01

    (delete

      save

    findOne

    count

    getOne

      分页 

    排序   

    判断是否存在)

技术图片
  1 package com.wsc.core.test;
  2 
  3 import com.wsc.core.dao.AccountDao;
  4 import com.wsc.core.entity.Account;
  5 import org.junit.Test;
  6 import org.junit.runner.RunWith;
  7 import org.springframework.beans.factory.annotation.Autowired;
  8 import org.springframework.data.domain.Page;
  9 import org.springframework.data.domain.PageRequest;
 10 import org.springframework.data.domain.Sort;
 11 import org.springframework.test.context.ContextConfiguration;
 12 import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
 13 import org.springframework.transaction.annotation.Transactional;
 14 
 15 import java.util.List;
 16 
 17 /**
 18  * @version 1.0
 19  * @ClassName TestJPA
 20  * @Description TODO
 21  * @Author WSC
 22  * @Date 2019/8/16 13:12
 23  **/
 24 @RunWith(SpringJUnit4ClassRunner.class)
 25 @ContextConfiguration("classpath:applicationContext.xml")
 26 public class TestJPA {
 27     @Autowired
 28     private AccountDao accountDao;
 29     /**
 30      * 添加数据
 31      */
 32     @Test
 33     public void test01(){
 34 //        ClassPathXmlApplicationContext applicationContext = new ClassPathXmlApplicationContext("classpath:applicationContext.xml");
 35 //        AccountDao accountDao = applicationContext.getBean(AccountDao.class);
 36         Account account = new Account();
 37         account.setAcAddress("提阿女号");
 38         account.setAcAge(133);
 39         account.setAcName("zhang");
 40         this.accountDao.save(account);
 41     }
 42     /**
 43      * 删除数据
 44      */
 45     @Test
 46     public void test02(){
 47         accountDao.delete(22);
 48     }
 49     /**
 50      * 修改数据
 51      */
 52     @Test
 53     public void test03(){
 54         Account account = accountDao.findOne(23);
 55         account.setAcName("阿凡提123");
 56         account.setAcAddress("美丽的郑州");
 57         accountDao.save(account);
 58     }
 59     /**
 60      * 查询单个数据  findOne 方法
 61      */
 62     @Test
 63     public void test04(){
 64         Account one = accountDao.findOne(23);
 65         System.out.println(one);
 66     }
 67     /**
 68      * 查询数据的总个数 count 方法
 69      */
 70     @Test
 71     public void getCount(){
 72         long count = accountDao.count();
 73         System.out.println(count);
 74     }
 75     /**
 76      * 获得数据单个
 77      * 必须加注解   @Transactional 事务注解
 78      *  不加报错:could not initialize proxy - no Session
 79      */
 80     @Test
 81     @Transactional
 82     public void getFindOne(){
 83         Account one = accountDao.getOne(23);
 84         System.out.println(one);
 85     }
 86     /**
 87      * 分页功能
 88      */
 89     @Test
 90     public void testPage(){
 91         PageRequest pageRequest = new PageRequest(0, 5);
 92         Page<Account> accountPage = accountDao.findAll(pageRequest);
 93         //总的数据条数
 94         long totalElements = accountPage.getTotalElements();
 95         System.out.println(totalElements);
 96         //总的页数
 97         int totalPages = accountPage.getTotalPages();
 98         System.out.println(totalPages);
 99         //遍历数据
100       for(Account account:accountPage){
101           System.out.println(account);
102       }
103         List<Account> accountList = accountPage.getContent();
104         System.out.println(accountList);
105     }
106     /**
107      * 排序 Sort.Direction.DESC 降序
108      */
109     @Test
110     public void testSort(){
111         // 创建一个sort  对象
112         //  参数1  排序方式
113         // 参数2  排序的字段  应该是实体类的属性名
114         Sort sort = new Sort(Sort.Direction.DESC,"acId");
115         List<Account> accountList = accountDao.findAll(sort);
116         for(Account account:accountList)
117              System.out.println(account);
118     }
119     /**
120      * 判断 是否 存在 exists
121      */
122     @Test
123     public void testExists(){
124         boolean exists = accountDao.exists(1);
125         System.out.println(exists);
126     }
127 }
test01

  test02

  (  全部信息

     根据id查 

  分页 

   模糊查询 原生SQL    

  方 法命名规则查询
  模糊查询  方 法命名规则查询
  根据 名字 模糊查询 并 分页)
技术图片
  1 package com.wsc.core.test;
  2 
  3 import com.wsc.core.dao.AccountDao;
  4 import com.wsc.core.entity.Account;
  5 import org.junit.Test;
  6 import org.junit.runner.RunWith;
  7 import org.springframework.beans.factory.annotation.Autowired;
  8 import org.springframework.data.domain.Page;
  9 import org.springframework.data.domain.PageRequest;
 10 import org.springframework.test.context.ContextConfiguration;
 11 import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
 12 
 13 import java.util.List;
 14 
 15 /**
 16  * @version 1.0
 17  * @ClassName Test02
 18  * @Description TODO
 19  * @Author WSC
 20  * @Date 2019/8/19 14:32
 21  **/
 22 @RunWith(SpringJUnit4ClassRunner.class)
 23 @ContextConfiguration("classpath:applicationContext.xml")
 24 public class Test02 {
 25     @Autowired
 26     private AccountDao accountDao;
 27 
 28     /**
 29      * 全部信息
 30      */
 31     @Test
 32     public void testFindAll() {
 33         List<Account> findAll = accountDao.getFindAll();
 34         for (Account account : findAll) {
 35             System.out.println(account);
 36         }
 37     }
 38 
 39     /**
 40      * id  信息
 41      */
 42     @Test
 43     public void getById() {
 44         Account findById = accountDao.getFindById(3L);
 45         System.out.println(findById);
 46     }
 47 
 48     /**
 49      * 查询全部  分页
 50      */
 51     @Test
 52     public void getByPage() {
 53         // 参数 1:页面开始  2: 页面数据条数
 54         PageRequest pageRequest = new PageRequest(0, 5);
 55         List<Account> findAllByPage = accountDao.getFindAllByPage(pageRequest);
 56         for (Account account:findAllByPage) {
 57             System.out.println(account);
 58         }
 59     }
 60 
 61     /**
 62      * 模糊查询
 63      */
 64     @Test
 65     public void get02(){
 66         List<Account> byName = accountDao.findByName("%2%", "%中%");
 67         for(Account account:byName){
 68             System.out.println(account);
 69         }
 70     }
 71     @Test
 72     public v                    

人气教程排行