본문 바로가기

Programming

(136)
Oracle to MySQL 변환 시 고려사항 (RDBMS) Oracle 에서 MySQL 로 변환.. 일반적인 변환 이유 고려할 사항들 RDBMS 변환 시 전체적인 계획 일반적인 변환 이유 비용문제 노후 시스템 개선 등 고려사항 데이터타입 Subquery alias (mysql 에서는 subquery에 alias 없으면 쿼리에러 발생) Mysql 은 대소문자를 구분함 (설치 시 구분여부 설정 가능) 함수 명칭 (IFNULL, NOW, CASE, CAST, DATE_ADD 등) Oracle 에서만 지원하는 구문/함수 들 (sequence, rownum, join, pivot 등) 계층형 쿼리 || (pipe_as_concat -> cancat_ws) 공백문자를 null로 취급하는 것의 차이 Dynamic where 차이 Byte 입력 및 byte 연산 차이 (함수 ..
[LeetCode] 1742. Maximum Number of Balls in a Box (TDD, 코테, 릿코드, tech interview) TDD로 알고리즘 풀이 후 리팩토링 리팩토링해서 함수만들고 하면 성능이 좀 떨어짐 테스트코드 package algorithm_sites.leetcode; import org.assertj.core.api.Assertions; import org.junit.jupiter.api.Test; public class LeetCode_1742_MaximumNumberOfBallsInABoxTest { private LeetCode_1742_MaximumNumberOfBallsInABox test = new LeetCode_1742_MaximumNumberOfBallsInABox(); @Test public void countBallsTest() { Assertions.assertThat(test.countBall..
[LeetCode] 2085. Count common words with one occurrence (코딩테스트, 테스트케이스 포함, 릿코드, tech interview) 깃허브에 커밋해서 문제풀이 블로그 포스팅은 잘 안했지만 재미로 쉬운거만 계속 풀고 있음 요새는 테스트케이스를 미리 추가해놓고 푸는 방식으로 하는 중 // Process // 1. Input 2 string arrays // 2. 한개 배열씩 반복한다. // 2.1. 중복안되는 것들의 배열을 각각 만든다. // 3. 중복안되는 것들의 배열 2개에서 서로 중복되는 개수를 센다. // 4. 개수 반환한다. public int countWords(String[] words1, String[] words2) { int result = 0; Set repeated = new HashSet(); Set set1 = new HashSet(); Set set2 = new HashSet(); // 2. for (Strin..
Gradle 의존 키워드의 차이점 (compile vs implementation + api, Gradle dependency configurations diff) Gradle 의존 키워드의 차이점 (compile vs implementation + api, Gradle dependency configurations diff) 배경 각각의 특징 및 차이점 Reference 배경 gradle 3.0 부터 compile 키워드가 deprecated 되었다. 각각의 특징 및 차이점 api 또는 compile 가장 상위의 의존을 시작하는 app 에서, 직접 의존하고 있는 것이 의존하고 있는 하위의 간접 의존에도 접근이 가능하다. implementation 가장 상위의 의존을 시작하는 app 에서, 직접 의존하는 것만 가능하다. 추천 사용법 api : app 에서 직접의존+간접의존 하는 내용을 전부 보여주고 싶다면 implementation : app 에서 직접의존 하는 내..
RPC, 근데 이제 Json을 곁들인.. (Json-RPC) RPC, 근데 이제 Json을 곁들인.. (Json-RPC) RPC 란 무엇인가? Json 이란 무엇인가? RPC 가 사용되는 이유 RPC 동작 방식 Json-RPC 특징 추가: gRPC는? HTTP 위에 얹는 Json-RPC 스타일 RPC 란 무엇인가? Remote Procedure Call (원격 프로시져 호출) 언어나 환경 등에 종속되지 않고 서비스 간 프로시저를 호출하도록 해주는 개념 분산컴퓨팅 환경에서 많이 사용됨 프로세스 간 통신 (Inter-Process Communication) 의 한 형태 클라이언트-서버 관계로 요청-응답 시스템 클라이언트에서 서버로 필요한 파라미터를 보내어 프로시저를 동작시킨다. Json 이란 무엇인가? JavaScript Object Notation 데이터 교환 형식..
개발자의 글쓰기 - 책정리 개발자의 글쓰기 완독했으나 그냥 가장 정리해보고 싶은 챕터라서 정리해봄 7장. 기술 블로그 쉽게 쓰고 운영하기 1. 기술 블로그를 쉽게 쓰는 방법 3가지 1. 소재우선 글쓰기 (주제의식을 버리고 소재의식으로 글쓰기) 2. 자기 수준 글쓰기 (핵심 내용만 쓰고 나머지는 독자가 공부할 수 있게 길만 터둔다) 3. 재미있는 글쓰기 (글쓴이의 경험 등을 기교와 녹여낸다) 2. 글의 종류로 목차를 잡는 법 (저, 술, 편, 집) 구분 내용 종류 저 직접 경험하고 실험한 과정이나 결과 개발기, 도입기, 적용기 술 어떤 것을 분석하여 의미를 풀이하고 해석한 것 기술 소개, 용어 분석, 에러 해결 방법 등 편 산만하고 복잡한 자료를 편집해 질서를 부여한 것 프로그램 설치/설정 방법, 튜토리얼, 세미나 후기, 책 리뷰 ..
객체지향의 사실과 오해 (The Essence of Object-Orientation) - 책정리 객체지향의 사실과 오해 (The Essence of Object-Orientation) 역할, 책임, 협력 관점에서 본 객체지향 Roles, Responsibilities, and Collaborations 1. 협력하는 객체들의 공동체 역할, 책임, 협력 역할은 기대되는 책임이 있고, 각 역할들이 협력해서 원하는 것들을 해낸다. 동일한 역할 중복 가능 역할은 대체 가능함 책임을 수행하는 방법은 선택 가능 (동일 요청에 다른 방식 응답 - 다형성) 하나가 여러 역할 수행 가능 객체의 덕목 2가지: 협력적, 자율적 협력은 메시지를 통해 이루어진다. 요청을 표현하는 메시지와, 요청을 처리하는 구체적 방법인 메서드를 분리하는 것은 자율성을 높이는데에 도움이 되고, 캡슐화(encapsulation)와 관련이 깊..
소프트웨어 장인 (프로페셔널리즘, 실용주의, 자부심) 책 정리 소프트웨어 장인 (The Software Craftsman) - 산드로 만쿠소 지음 1. 21세기의 소프트웨어 개발 예전의 개발 문화 새로운 문화 (최근) 소프트웨어 장인정신이 필요해졌다. 2. 애자일 (Agile, 민첩) 나오게 된 배경은 이전 시대의 워터폴 방식의 부족함에서 출발 분류 절차적 관점: 올바른 목표를 향해 가는지 확인 기술적인 관점: 목표한 것을 올바르게 실행하고 있는지 확인 애자일 메니페스토(menifesto, 선언문) 원칙들 실제 애자일을 실행할 때 기업들은 오해를 한다. 절차적인 것을 중시하고 기술적인 것은 무시한다. 소웨 개발자들의 기술은 완벽하고 절차만 고치면 된다는 식의 사고방식은 안된다. 기업 차원에서 소웨 장인정신이 필요하다 3. 소프트웨어 장인정신 정의: 소프트웨어 개발의..