본문 바로가기

728x90

Backend

(70)
[Oracle] MERGE INTO 사용법 테이블에 데이터가 이미 있으면 UPDATE 를 실행하고, 없을 경우 값을 INSERT 해줘야 하는 경우에 MERGE INTO 문을 통해 한 쿼리로 간단하게 작성할 수 있다. * 오라클 9i 버전 이상부터 사용 가능 (but 10g이상 사용 추천) 아래와 같이 사용한다. MERGE INTO "테이블 명" USING "테이블 or 뷰 or 서브쿼리" ON ( " 조건절1" AND " 조건절2 " ... )-- 값이 있는지 확인 WHEN MATCHED THEN --있으면 UPDATE SET [COLUMN1] = [VALUE1], [COLUMN2] = [VALUE2], WHEN NOT MATCHED THEN --없으면 INSERT (COLUMN1, COLUMN2, ...) VALUES (VALUE1, VALUE..
RestTemplate 사용법 (2) Naver API 사용하기 프로젝트를 작업하다 보면, Open API를 사용해야하는 경우가 많다. RestTemplate를 사용하여 간단하게 연동하는 법에 대해서 알아보겠다. Naver 지역 검색 API 연동하는 법에 대해서 알아보겠다. 지역 - Search API 지역 NAVER Developers - 검색 API 지역 검색 개발가이드 검색 > 지역 네이버 지역 서비스에 등록된 각 지역별 업체 및 상호 검색 결과를 출력해주는 REST API입니다. 비로그인 오픈 API이므로 GET으로 호출 developers.naver.com 호출예시 // 네이버 검색 API 예제 - blog 검색 import java.io.*; import java.net.HttpURLConnection; import java.net.MalformedURLE..
RestTemplate 사용법 (1) - getForObject(), getForEntity() 백엔드 개발을 할때는 Server의 입장이 되어서 API를 제공해보는 것이 중요함. Client가 되어서 어떻게 실제로 서버에게 데이터를 던져주고, 받아오는지 알아보겠다. 1. 기본적인 RestTemplate사용 [GET]- getForObject() , getForEntity(); [Client] @RestController @RequestMapping("/api/client") public class ApiController { private final RestTemplateService restTemplateService; public ApiController(RestTemplateService restTemplateService) { this.restTemplateService = restTemp..
[스프링 인 액션 5장] Spring 자동구성, Logback 활용 Chap05 구성속성 이해하기 📖 Chap05.1 에서 배우는 내용 🏁 [목표] 스프링 자동구성에 대해서 알아보고, slf4j logback에 대해서 🏁 [익혀야 되는 개념] 1) 자동구성 ? 2) 로깅? logback, slf4j, log4j ? 5.1 자동-구성 세부 조정하기 5.1.0 두가지 형태의 구성 스프링 에는 두가지 형태의 구성이 있다. @Bean 애노테이션이 지정된 메서드는 사용하는 빈의 인스턴스를 생성하고 속성 값도 설정한다. 1) 빈 연결 : 스프링 애플리케이션 컨텍스트에서 빈으로 생성되는 애플리케이션 컴포넌트 및 상호 간에 주입되는 방법을 선언하는 구성 2) 속성 연결 : 스프링 애플리케이션 컨텍스트에서 빈의 속성 값을 설정하는 구성 // 스프링에 내장된 H2 DB를 DataSourc..
[스프링 인 액션 3장] Spring JDBC 사용 Chap03 데이터로 작업하기 📖 Chap03.1 에서 배우는 내용 🏁 [목표] Spring JDBC 개념과 사용법 익히기 🏁 [익혀야 되는 개념] 1) Spring 에서 JDBC를 이용하여 Database를 다루는 큰 그림 2) Plain JDBC와 Spring JDBC의 차이, Spring JDBC를 사용하는 이유? 3) Datasource의 Connection Pool 개념 4) JdbcTemplate을 이용하여 CRUD동작 구현하기 5) SimpleJdbcInsert 사용법 (+objectMapper 개념) 3.1.0 Spring에서 Database를 다루는 큰그림 client가 웹으로 request를 보내면 servlet으로 구현된 controller가 request를 받아, service 클래..
Spring Boot Test하기 [1] 테스트 TDD (Test-Driven Development) - 테스트 주도 개발에서 사용하지만, 코드의 유지보수 및 운영환경에서의 에러를 미리 방지하기 위해 단위별로 검증하는 테스트 프레임워크 단위테스트 - 작성한 코드가 기대하는 대로 동작을 하는지 검증하는 절차 JUnit - java기반의 단위 테스트를 위한 프레임워크 - Annotation 기반으로 테스트를 지원 Assert를 통하여 검증함. 서버를 구동하지 않고 컨트롤러만 단독으로 테스트하거나 컨트롤러와 연관된 비지니스 컴포넌트를 실행하지 않고 컨트롤러만 독립적으로 테스트 할 수 있는 환경이 필요. # 의존성 org.springframework.boot spring-boot-starter-test test # Controller : 뷰이름을 리턴..
AWS EC2 인스턴스가 안보이는경우 해결법 가끔 보안상 문제로 key 노출됐을때 인스턴스 안보이는 경우가 있음 그때 해결법. 안쓰는 EC2라면, 돈이 계속 나가므로 빠르게 해결해야됨. EC2 인스턴스가 안보임? -> 인스턴스 글로벌 보기 확인. 없던 인스턴스 확인 가능 이제 여기서 클릭후, 선택한 리소스 관리 ! (여기서부터는 검색하면 잘나옴) 인스턴스 상태 -> 중지후, 종료됨 클릭 끝!
Hypermedia-Driven RESTful Web Services : Spring HATEOAS 구현방법 [2] Spring에서 Hateoas를 구현하는 방법에 대해서 알아보겠다. ## 환경 : Spring Boot + IntellJ + Maven 0) Dependency org.springframework.boot spring-boot-starter-hateoas 1) Link 를 만들기 위하여 WebMvcLinkBuilder 활용 Link link = new Link("http://localhost:8080/api/actors/1"); // 링크를 만들때 위와 같이 하드코딩을 하지 않도록 WebMvcLinkBuilder를 사용 // # WebMvclinkBuilder를 사용하여 링크를 만든다. // Link Object에는 rel와 href를 넣는다. // rel : 이름 / href : 실제 링크 // lin..

728x90