전체 글

천천히 성장해 나가는 과정 속에서, 저의 지식을 많은 사람들과 공유하고 함께 성장해 나가기 위한 블로그입니다 🤗
Framework/Spring

Node.js와 Spring의 차이: 왜 Spring은 Tomcat 서버가 필요할까?

웹 애플리케이션을 개발하다 보면 Node.js와 Spring의 차이를 자주 접하게 됩니다. 특히, 많은 개발자들이 "Node.js는 그냥 실행되는데, 왜 Spring은 Tomcat 같은 서버가 필요한 걸까?"라는 질문을 하곤 합니다. 이번 글에서는 그 차이를 명확하게 설명하고, 두 환경의 동작 방식을 비교해보겠습니다! 1. Node.js : 자체 서버로 동작하는 JavaScript 런타임Node.js는 JavaScript 런타임 환경으로, 기본적으로 웹 서버의 기능을 포함하고 있습니다. Node.js에서는 별도의 서버 없이도 애플리케이션을 실행하고 클라이언트 요청을 처리할 수 있습니다. 대표적인 웹 프레임워크인 Express.js를 예로 들어보면, Express.js가 서버 역할을 하면서 요청과 응답을 ..

DB/Oracle

Oracle SQL에서 컬럼 자동 증가하는 방법

Oracle에서 자동 증가하는 방법, SEQUENCE와 IDENTITY 컬럼데이터베이스에서 기본 키로 사용되는 값이 자동으로 증가하는 기능은 매우 흔하게 사용됩니다. Oracle에서는 이 기능을 구현하기 위해 주로 SEQUENCE를 사용하지만, Oracle 12c부터는 IDENTITY 컬럼도 지원됩니다. 이번 글에서는 두 가지 방법에 대해 설명해보겠습니다!1. SEQUENCE를 사용하는 방법Oracle에서 자동 증가하는 값을 생성하기 위해 가장 전통적으로 사용되는 방법은 SEQUENCE입니다. SEQUENCE는 단순히 고유한 숫자를 생성해주는 객체로, 특정 규칙에 따라 숫자가 증가합니다.1-1. SEQUENCE 생성하기아래는 SEQUENCE를 생성하는 기본 예제입니다.CREATE SEQUENCE seq_..

Framework/Spring

[Spring] PRG (Post/Redirect/Get) 패턴이란 무엇일까?

PRG (Post/Redirect/Get) 패턴 : 중복 데이터 제출을 막는 웹 개발의 필수 설계 패턴웹 애플리케이션을 개발하다 보면 폼 데이터를 처리하는 과정에서 종종 발생하는 문제가 있습니다. 사용자가 폼을 제출한 후 새로고침(F5)을 누르면 동일한 요청이 다시 서버로 전송되어 중복 데이터가 생성되는 상황입니다. 이때 PRG (Post/Redirect/Get) 패턴은 이러한 문제를 효과적으로 해결할 수 있는 설계 패턴입니다. 이번 글에서는 PRG 패턴이 무엇인지, 왜 필요한지, 그리고 이를 어떻게 구현할 수 있는지에 대해 살펴보겠습니다!! PRG 패턴이란?PRG 패턴은 웹 애플리케이션에서 폼 제출 후 새로고침 시 중복 요청을 방지하기 위해 고안된 설계 패턴입니다. 기본적인 흐름은 다음과 같습니다.Po..

Framework/Spring

JPA에서 @GeneratedValue와 GenerationType에 대해 알아보자

JPA에서 엔티티의 기본 키를 자동으로 생성하는 전략은 애플리케이션의 성능과 데이터베이스의 특성에 영향을 미치는데요. 이러한 전략은 @GeneratedValue 어노테이션에서 GenerationType을 통해 지정할 수 있습니다. 이 글에서는 JPA에서 제공하는 네 가지 키 생성 전략인 IDENTITY, SEQUENCE, AUTO, TABLE의 의미와 동작 방식에 대해 알아보도록 하겠습니다!1. GenerationType.IDENTITYIDENTITY 전략은 주로 Auto Increment 기능을 제공하는 데이터베이스에서 사용됩니다. 이 전략은 기본 키를 데이터베이스에서 자동으로 생성하도록 합니다. MySQL과 PostgreSQL과 같은 데이터베이스에서 많이 사용되며, AUTO_INCREMENT나 SER..

CS & Network

[Network] HTTP/HTTPS 프로토콜에 관하여

HTTP란?HTTP(HyperText Transfer Protocol)는 인터넷에서 클라이언트와 서버 간에 데이터를 주고 받기 위해 사용하는 프로토콜 입니다.HTTP는 요청-응답 프로토콜이라고도 합니다. 예를 들자면 구글 웹 사이트에 접속하는 경우를 생각해봅시다. 사용자가 웹 브라우저의 주소 표시줄에 'www.google.com'을 입력하면 웹 브라우저(클라이언트)는 구글 서버에 '구글 웹사이트를 사용자에게 보여주기 위한 데이터를 전송해줘' 라는 HTTP 요청을 합니다. 요청을 받은 구글 서버는 웹 사이트를 띄우는데 필요한 데이터, 즉 HTML, CSS, 이미지 파일 등을 HTTP 응답으로 보냅니다. 데이터를 전달받은 웹 브라우저는 각 요소를 적절히 조합해 구글 웹사이트를 사용자의 화면에 출력합니다. H..

Programming/JAVA

Java의 public static void main 메서드 이해하기

Java의 public static void main 메서드 이해하기Java 프로그래밍을 시작하면 가장 먼저 접하게 되는 것이 바로 public static void main(String[] args) 메서드인데요. 이 메서드는 Java 프로그램의 진입점으로, 프로그램 실행의 시작 지점입니다.이번 글에서는 이 메서드의 각 키워드가 어떤 역할을 하는지에 대해 알아보도록 하겠습니다!1. public역할 : 접근 제한자(Access Modifier)설명 : public 키워드는 메서드가 어디서나 접근 가능하다는 것을 의미합니다. 즉, 다른 클래스에서도 이 메서드를 호출할 수 있습니다. 메인 메서드는 JVM(Java Virtual Machine)에서 호출해야 하기 때문에 public으로 선언합니다. 2. sta..

Coding Test/프로그래머스

[Java] 진료 순서 정하기

문제설명 외과의사 머쓱이는 응급실에 온 환자의 응급도를 기준으로 진료 순서를 정하려고 합니다. 정수 배열 emergency가 매개변수로 주어질 때 응급도가 높은 순서대로 진료 순서를 정한 배열을 return하도록 solution 함수를 완성해주세요. 제한사항 중복된 원소는 없습니다. 1 ≤ emergency의 길이 ≤ 10 1 ≤ emergency의 원소 ≤ 100 입출력 예 입출력 예 설명 입출력 예 #1 emergency가 [3, 76, 24]이므로 응급도의 크기 순서대로 번호를 매긴 [3, 1, 2]를 return합니다. 입출력 예 #2 emergency가 [1, 2, 3, 4, 5, 6, 7]이므로 응급도의 크기 순서대로 번호를 매긴 [7, 6, 5, 4, 3, 2, 1]를 return합니다. 입..

Coding Test/프로그래머스

[Java] 배열의 길이를 2의 거듭제곱으로 만들기

문제설명 정수 배열 arr이 매개변수로 주어집니다. arr의 길이가 2의 정수 거듭제곱이 되도록 arr 뒤에 정수 0을 추가하려고 합니다. arr에 최소한의 개수로 0을 추가한 배열을 return 하는 solution 함수를 작성해 주세요. 제한사항 1 ≤ arr의 길이 ≤ 1,000 1 ≤ arr의 원소 ≤ 1,000 입출력 예 입출력 예 설명 입출력 예 #1 예제 1번의 arr의 길이는 6입니다. arr의 길이를 2의 정수 거듭제곱으로 만드는 방법은 0을 2개, 10개, 26개,..., 추가하는 방법이 있고 그중 최소한으로 0을 추가하는 방법은 2개를 추가하는 것입니다. 따라서 [1, 2, 3, 4, 5, 6, 0, 0]을 return 합니다. 입출력 예 #2 예제 2번의 arr의 길이는 4이고 이미..

Programming/JAVA

[Java] 배열, 콜렉션 정렬하는 방법에 대해 알아보기

자바에서는 다양한 방법으로 배열과 컬렉션을 정렬할 수 있는데요. 가장 일반적인 방법은 Arrays.sort()와 Collections.sort() 메서드를 사용하는 것입니다! 하지만 이 외에도 Comparator와 Comparable 인터페이스를 구현하여 사용자 정의 정렬 기준을 지정할 수도 있는데요. 아래에서 각각의 방법을 설명해보도록 하겠습니다! 1. 배열 정렬 Arrays.sort() 배열을 정렬합니다. 기본적으로 오름차순으로 정렬됩니다. Comparable 인터페이스를 구현한 객체의 배열은 기본 정렬 기준에 따라 정렬됩니다. int[] array = {3, 1, 4, 1, 5, 9, 2, 6}; Arrays.sort(array); // 오름차순으로 정렬 사용자 정의 Comparator를 이용한 배..

노 코딩 노 라이프
rei050r