天天看點

SpringDataJPA之CrudRepository接口

 上篇我們介紹了Repository接口,發現該接口并沒有提供完成的DML操作,SpringDataJPA中完成的CRUD操作是通過CrudRepository接口來實作的。

CrudRepository接口

 CrudRepository接口繼承自Repository接口,是以Repository接口具有的功能CrudRepository接口都具有,同時又擴充了CRUD相關的功能

API方法介紹

 CrudRepository接口提供了如下的方法:

@NoRepositoryBean
public interface CrudRepository<T, ID extends Serializable> extends Repository<T, ID> {

    <S extends T> S save(S entity);
    <S extends T> Iterable<S> save(Iterable<S> entities);
    T findOne(ID id);
    boolean exists(ID id);
    Iterable<T> findAll();
    Iterable<T> findAll(Iterable<ID> ids);
    long count();
    void delete(ID id);
    void delete(T entity);
    void delete(Iterable<? extends T> entities);
    void deleteAll();
}      

去掉了相關的注釋,通過方法名稱我們也能很清楚的知道每個方法的功能。

具體使用

1.聲明Dao接口

/**
 * CrudRepository 接口使用
 * 定義的方法名稱 參考文檔定義
 */
public interface UserDao extends CrudRepository<Users,Integer> {

}      

2.單元測試

/**
 * @program: spring-data-jpa 
 * @description: 單元測試
 * @author: 波波烤鴨
 * @create: 2019-05-18 09:48
 */
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:applicationContext.xml")
public class TestDemo {

    @Autowired
    private UserDao usersDao;


    /**
     * 添加單條資料
     */
    @Test
    public void test1(){
        Users user = new Users();
        user.setUserage(21);
        user.setUsername("趙小麗");
        this.usersDao.save(user);
    }
    /**
     * 批量添加資料
     */
    @Test
    public void test2(){
        Users user = new Users();
        user.setUserage(21);
        user.setUsername("趙小麗");
        Users user1 = new Users();
        user1.setUserage(25);
        user1.setUsername("王小虎");
        List<Users> list= new ArrayList<>();
        list.add(user);
        list.add(user1);
        this.usersDao.save(list);
    }
    /**
     * 根據 ID 查詢單條資料
     */
    @Test
    public void test3(){
        Users users = this.usersDao.findOne(13);
        System.out.println(users);
    }
    /**
     * 查詢全部資料
     */
    @Test
    public void test4(){
        List<Users> list = (List<Users>)this.usersDao.findAll();
        for (Users users : list) {
            System.out.println(users);
        }
    }
    /**
     * 删除資料
     */
    @Test
    public void test5(){
        this.usersDao.delete(13);
    }
    /**
     * 更新資料 方式一
     */
    @Test
    public void test6(){
        Users user = this.usersDao.findOne(12);
        user.setUsername("王小紅");
        this.usersDao.save(user);
    }
    /**
     * 更新資料 方式二
     */
    @Test
    @Transactional
    @Rollback(false)
    public void test7(){
        Users user = this.usersDao.findOne(12);//持久化狀态的
        user.setUsername("王小小");
    }

}
      
SpringDataJPA之CrudRepository接口