💻Development
-
[Spring DB] 커넥션풀과 데이터소스 이해Study/Spring 2025. 7. 12. 15:35
커넥션 풀 이해데이터베이스 커넥션을 매번 획득 데이터베이스 커넥션을 획득할 때는 아래 과정을 거침어플리케이션 로직은 DB 드라이버를 통해 커넥션을 조회한다.DB 드라이버는 DB와 TCP/IP 커넥션을 연결한다. 이 과정에서 3 Way Handshake 같은 TCP/IP 연결을 위한 네트워크 동작이 발생한다.DB 드라이버는 TCP/IP 커넥션이 연결되면 ID, PW와 기타 부가정보를 DB에 전달한다.DB는 ID, PW를 통해 내부 인증을 완료하고, 내부에 DB 세션을 생성한다.DB는 커넥션 생성이 완료되었다는 응답을 보낸다.DB 드라이버는 커넥션 객체를 생성해서 클라이언트에 반환한다. 단점커넥션을 새로 만드는 것은 과정도 복잡하고 시간도 많이 소요됨DB와 어플리케이션 서버 모두 TCP/IP 커넥션을 새로 ..
-
[Spring DB] 데이터 접근 핵심 원리 - JDBC 이해Study/Spring 2025. 6. 28. 23:15
JDBC 이해JDBC 등장 이유어플리케이션 서버와 DB - 일반적인 사용법커넥션 연결 : 주로 TCP/IP를 사용해서 커넥션을 연결한다.SQL 전달 : 어플리케이션 서버는 DB가 이해할 수 있는 SQL을 연결된 커넥션을 통해 DB에 전달한다.결과 응답 : DB는 전달된 SQL을 수행하고 그 결과를 응답한다. 어플리케이션 서버는 응답 결과를 활용한다. 어플리케이션 서버와 DB - DB 변경각각의 데이터베이스마다 커넥션을 연결하는 방법, SQL을 전달하는 방법, 결과를 응답 받는 방법이 모두 다름이런 문제를 해결하기 위해 JDBC라는 자바 표준이 등장함 JDBC 표준 인터페이스대표적으로 다음 3가지 기능을 표준 인터페이스로 정의해서 제공함java.sql.Connection - 연결java.sql.Statem..
-
[stack] valid parenthesesAlgorithm/LeetCode 2025. 6. 7. 11:42
✅ Problemhttps://leetcode.com/problems/valid-parentheses/description/ ✅ Approach & Solution방식1) stack, map 사용더보기class Solution { public boolean isValid(String s) { // 유효성 검증을 위한 스택 선언 Deque stack = new ArrayDeque(); // 매핑 테이블 선언 Map table = new HashMap(){{ put(')', '('); put('}', '{'); put(']', '['); }}; // 한 문자씩 처리 ..
-
[linked list] reverse linked list 2Algorithm/LeetCode 2025. 6. 6. 12:11
✅ Problemhttps://leetcode.com/problems/reverse-linked-list-ii/description/ ✅ Approach & Solution방식)더보기head 노드를 가리키는 임시 노드를 생성한다.start와 end 노드를 고정하고 한 단계씩 뒤집기를 수행한다./** * Definition for singly-linked list. * public class ListNode { * int val; * ListNode next; * ListNode() {} * ListNode(int val) { this.val = val; } * ListNode(int val, ListNode next) { this.val = val; this.next ..