jpaのPagingAndSortingRepositoryページクエリ
3414 ワード
この文章はspring統合jpa環境の基礎の上で創立して、できないのは前のいくつかの文章を見てください.
1.1.DaoインタフェースPagingAndSortingRepositoryインタフェースの継承
PersonDao.java
1.2.PagingAndSortingRepositoryインタフェースを使用する方法
1.2.1.新規作成
1.2.2.削除
1.2.3.変更
1.2.4.検索
1.2.5.ページングクエリ
ここでPageableはインタフェースであり、具体的な実装クラスはPageRequestであり、以下はPageRequestの構築方法である.
改ページ時のページ数と各ページのサイズを指定するだけでよい.
1.3.ソースコード
IPersonService
PersonServiceImpl.java
1.1.DaoインタフェースPagingAndSortingRepositoryインタフェースの継承
PersonDao.java
package com.morris.dao.inter;
import org.springframework.data.repository.PagingAndSortingRepository;
import com.morris.entity.Person;
public interface PersonDao extends PagingAndSortingRepository{
}
1.2.PagingAndSortingRepositoryインタフェースを使用する方法
1.2.1.新規作成
public void save(Person person) {
personDao.save(person);
}
1.2.2.削除
public void delete(Person person) {
personDao.delete(person);
}
public void delete(Integer id) {
personDao.delete(id);
}
1.2.3.変更
public void update(Person person) {
personDao.save(person);
}
1.2.4.検索
public Person findById(Integer id) {
Person person = personDao.findOne(id);
return person;
}
public Iterable findAll() {
Iterable persons = personDao.findAll();
return persons;
}
1.2.5.ページングクエリ
public Iterable findAll(Pageable pageable) {
Page persons = personDao.findAll(pageable);
return persons;
}
ここでPageableはインタフェースであり、具体的な実装クラスはPageRequestであり、以下はPageRequestの構築方法である.
public PageRequest(int page, int size)
{
this(page, size, null);
}
改ページ時のページ数と各ページのサイズを指定するだけでよい.
1.3.ソースコード
IPersonService
package com.morris.service.inter;
import org.springframework.data.domain.Pageable;
import com.morris.entity.Person;
public interface IPersonService {
void save(Person person);
void delete(Person person);
void delete(Integer id);
void update(Person person);
Person findById(Integer id);
Iterable findAll();
Iterable findAll(Pageable pageable);
}
PersonServiceImpl.java
package com.morris.service.impl;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.stereotype.Service;
import com.morris.dao.inter.PersonDao;
import com.morris.entity.Person;
import com.morris.service.inter.IPersonService;
@Service("personService")
public class PersonServiceImpl implements IPersonService {
@Autowired
private PersonDao personDao;
public void save(Person person) {
personDao.save(person);
}
public void delete(Person person) {
personDao.delete(person);
}
public void delete(Integer id) {
personDao.delete(id);
}
public void update(Person person) {
personDao.save(person);
}
public Person findById(Integer id) {
Person person = personDao.findOne(id);
return person;
}
public Iterable findAll() {
Iterable persons = personDao.findAll();
return persons;
}
public Iterable findAll(Pageable pageable) {
Page persons = personDao.findAll(pageable);
return persons;
}
}