본문 바로가기

머어어엉

(104)
java jpa sql 오류) Loading class `com.mysql.jdbc.Driver'. This is deprecated. The new driver class is `com.mysql.cj.jdbc.Driver'. The driver is automatically registered via the SPI and manual loading of the driver class is generally unnecessary. Mysql 오류
오라클 오류) ORA-12526, TNS:listener: all appropriate instances are in restricted mode ORA-12526, TNS:listener: all appropriate instances are in restricted mode (SID_DESC = (GLOBAL_DBNAME = ORA12C) (ORACLE_HOME = D:\app\woom\product\11.2.0\dbhome_1) (SID_NAME = ORA12C) ) 추가
인텔리제이) 스프링부트 + 마이바티스 yml 설정 type-aliases-package: 매핑타입을 짧게 쓰기위한 경로 설정 mapper-locations: xml 맵퍼 위치 경로 설정 @Mapper 어노테이션 설정 맵퍼 클래스는 interface 로 구현
결과 조회, 정렬, 페이징 * 결과조회 fetch() : 리스트 조회, 데이터 없으면 빈 리스트 반환 fetchOne() : 단 건 조회 결과가 없으면 : null 결과가 둘 이상이면 : com.querydsl.core.NonUniqueResultException fetchFirst() : limit(1).fetchOne() fetchResults() : 페이징 정보 포함, total count 쿼리 추가 실행 fetchCount() : count 쿼리로 변경해서 count 수 조회 //List List fetch = queryFactory .selectFrom(member) .fetch(); //단 건 Member findMember1 = queryFactory .selectFrom(member) .fetchOne(); //처음..
기본 문법 * JPQL vs Querydsl @Test public void startJPQL() { //member1을 찾아라 Member findMember = em.createQuery("select m from Member m where m.username = :username", Member.class) .setParameter("username", "member1") .getSingleResult(); assertThat(findMember.getUsername()).isEqualTo("member1"); } @Test public void startQuerydsl() { Member find = queryFactory .select(member) .from(member) .where(member.use..
Querydsl 환경설정 * build.gradle 에 설정 하기 plugins { //querydsl 추가 id "com.ewerk.gradle.plugins.querydsl" version "1.0.10" } dependencies { //querydsl 추가 implementation 'com.querydsl:querydsl-jpa' } //querydsl 추가 시작 def querydslDir = "$buildDir/generated/querydsl" querydsl { jpa = true querydslSourcesDir = querydslDir } sourceSets { main.java.srcDir querydslDir } configurations { querydsl.extendsFrom compileClasspa..
확장기능 * 사용자 정의 리포지터리 구현 인터페이스는 아무이름이나 상관없음 그러나 구현하는 클래스 이름은 MemberRepository + Impl 붙여서 생성한다. public interface MemberRepositoryCustom { List findMemberCustom(); } @RequiredArgsConstructor public class MemberRepositoryImpl implements MemberRepositoryCustom { private final EntityManager em; @Override public List findMemberCustom() { return em.createQuery("select m from Member m") .getResultList(); } } p..
Spring Data JPA 페이징 org.springframework.data.domain.Sort; org.springframework.data.domain.Page; org.springframework.data.domain.PageRequest; Sort : 정렬기능 Pageable : 페이징기능 * 반환타입 Page : totalCount 가 포함 된 페이징 Slice : totalCount 미포함 ( 모바일에 더보기 기능 같은거) public interface MemberRepository extends JpaRepository { Page findByAge(int age, Pageable pageable); } @Test public void paging() { memberRepository.save(new Member("mem..