코딩공부
-
[MySQL 8.0] 선착순 쿠폰 발급 로직 구현에 대한 고찰코딩공부 2025. 1. 28. 03:35
최근 MySQL을 공부하면서 선착순 쿠폰 발급을 효율적으로 처리하는 로직을 고민해보았습니다.이 글에서는 MySQL 8.0의 고급 기능을 활용하여 동시성 제어와 쿠폰 발급 로직을 구현하는 방법을 정리해 보겠습니다.MySQL 8.0 고급 기능MySQL에서 SELECT ~ FOR UPDATE를 사용하면 다른 트랜잭션에서 읽기나 쓰기를 시도할 경우 해당 행이 잠금이 해제될 때까지 대기하게 되는데 MySQL 8.0에서는 이를 보완하고 동시성을 효율적으로 처리하기 위해 다음과 같은 기능이 추가되었습니다.1. NO WAIT해당 기능은 잠금된 행을 만나면 대기하지 않고 즉시 예외(Lock wait timeout exceeded)를 던집니다.2. SKIP LOCKED해당 기능은 잠금되지 않은 행만을 대상으로 작업을 수행..
-
[Go 기초] 얕은 복사? Error?코딩공부 2025. 1. 22. 18:23
Go 언어에서 값 타입은 복사할 때 깊은 복사가 이루어지며 참조 타입은 얕은 복사가 이루어집니다.1. 값 타입 (Value Type)값 타입은 변수에 할당될 때 값 자체가 복사(깊은 복사)됩니다.Go에서 기본적으로 제공하는 값 타입으로는 int, float, struct 등이 있습니다.package mainimport "fmt"type Jang struct { X, Y int}func (j *Jang) Jangto(i int) { j.X = j.X * i j.Y = j.Y * i}func JangTest() { originV := Jang{1, 2} copyV := originV // 깊은 복사 copyV.Jangto(2) fmt.Println("origin..
-
AOP를 통한 유지 보수성 향상 - 프로젝트의 매개변수 관리 혁신코딩공부 2024. 9. 22. 00:53
1) 문제발견프로젝트에서 각 화면 별 Controller가 JSP를 호출할 때, Model에 로직 수행 후 결과를 담으며 다른 Controller에서는 매개변수가 있을때 그 매개변수에 세팅을 해줘야 하는 구조로 설계되었습니다. 총 100개 이상의 화면이 존재하는 상황에서 프로젝트 완료 시점에 Controller의 매개변수가 수정되는 문제가 발생했습니다. 이로 인해 각 Controller에서 매개변수를 개별적으로 수정해야 하는 비효율이 생겼고 이는 코드의 일관성과 유지 보수에 큰 부담이 되었습니다.2) 해결이 문제를 해결하기 위해 AOP(Aspect-Oriented Programming)를 도입했습니다. AOP를 통해 매개변수 관리 로직을 중앙 집중화하여 코드의 가독성과 유지 보수성을 극대화했습니다. 구체..
-
각 화면의 기능을 공통 인터페이스로 분리코딩공부 2024. 9. 21. 19:51
프로젝트 중 각 화면에 개별적으로 구현된 공통 기능들을 Footer와 같은 방식으로 항상 화면에 표시되도록 통합하고 디자인팀과 협력해 시각적인 디자인을 다듬어서 사용자 경험을 개선했으며 이를 통해 유지 보수성을 향상시켰습니다.1) 배경프로젝트에서 여러 화면에 공통된 기능이 있었으나 이를 개별적으로 구현한 방식은 사용자 편의성과 유지보수성에서 부족함이 있었습니다.이 문제에 대해 회의를 통해 공통 기능을 하나의 인터페이스로 통합하고 사용자에게 언제든지 접근할 수 있는 형태로 구현하도록 하였으며 해당 작업을 담당하게 되었습니다.2) 해결 방법 도출먼저 네이버의 오른쪽 하단에 위치한 스크롤 버튼 및 설정 버튼에서 영감을 얻어 공통 기능을 한 곳에 모아 사용자 편의성을 높이고자 했습니다.처음에는 버튼을 일렬로 배..
-
[AUIGrid] XSS 취약점 발견 및 해결 과정코딩공부 2024. 9. 21. 02:51
1) 문제 발견회사에서 사용 중인 AUIGrid라는 외부 라이브러리를 분석하던 중 사용자 입력을 바탕으로 그리드를 생성하는 과정에서 XSS(Cross-Site Scripting) 취약점이 존재함을 확인했습니다.AUIGrid는 사용자 입력을 직접 HTML에 삽입하는 InnerHTML 방식을 사용하는데 이는 악의적인 스크립트가 웹 페이지에 주입될 수 있기 때문에 시스템 보안에 심각한 위협이 될 수 있습니다.2) 문제 정의XSS 공격은 공격자가 웹 페이지에 악성 스크립트를 삽입하여 웹 애플리케이션의 정상적인 동작을 방해하거나 사용자의 민감한 정보를 탈취하는 공격 기법입니다.AUIGrid의 경우 사용자가 입력한 데이터가 필터링 없이 HTML에 직접 반영되기 때문에 공격자가 악의적인 스크립트를 입력하여 웹 페이지..
-
[Oracle] SQL Function 복습코딩공부 2023. 2. 26. 21:01
SQL의 함수에는 단일 행 함수와 그룹 함수로 나눠진다. 단일 행 함수 각 행마다 반복적으로 적용되어 입력 받은 행의 개수만큼 결과 반환 그룹 함수 특정 행들의 집합으로 그룹이 형성되어 적용되기 때문에 그룹 당 1개의 결과만 반환 문자 처리 함수 LENGTH, LENGTHB, INSTR, INSTRB 함수는 반환 값이 NUMBER이고 이를 제외한 나머지 함수의 반환 값은CHARACTER형이다. LENGTH(CHAR / STRING), LENGTHB(CHAR / STRING) SELECT LENGTH('HELLO'), -- 길이를 반환 (5) LENGTHB('HELLO'), -- 문자열 BYTE로 변환해서 반환 (5) LENGTH('안녕'), -- 길이를 반환 (2) LENGTHB('안녕'), -- BYT..
-
-
[Javascript] Array.reduce 문법코딩공부 2022. 5. 13. 17:26
구문 arr.reduce(callback[, initialValue]) callback은 4가지 인수를 받을 수 있습니다. accumulator currentValue currentIndex array 예제_1 [1,2,3,4,5].reduce((accumulator, currentValue)=>accumulator + currentValue); // initialValue 없는 경우 과정 1번째 호출 accumulator : 1 / currentValue : 2 / currentIndex : 1 return : 3 2번째 호출 accumulator : 3 / currentValue : 3 / currentIndex : 2 return : 6 3번째 호출 accumulator : 6 / currentVa..