본문 바로가기

반응형

진리는어디에

(289)
[MySQL] 그룹별 최대 or 최소 select하기 들어가며 SQL에서 제공하는 그룹 함수인 max(), min()을 이용하면 테이블에서 가장 큰 값과 작은 값을 쉽게 구할 수 있다. 하지만 각 그룹당 최대값과 최소값은 어떻게 구할 수 있을까? 예를 들면, 각 플레이어의 최고 점수는 얼마인가? 각 장르별 가장 인기있는 영화는? 이번 포스트에서는 각 항목에서 상위 1개 행을 구하는 방법에서 시작하여 N개 행을 선택하는 방법 까지 다뤄 보도록 하겠다. 본격적인 내용으로 들어가기 전에 이번 포스트에서 사용할 예제 테이블은 아래와 같다. CREATE TABLE `fruits` ( `type` VARCHAR(50) NOT NULL COMMENT '과일 종류/그룹', `variety` VARCHAR(50) NOT NULL COMMENT '과일 품종', `price`..
[VBA] 엑셀 매크로 시작 완벽 가이드 이 포스트는 Excel Macro Mastery 사이트의 'How To Create a Macro From Scratch in Excel(by Paul Kelly)'의 내용을 다시 정리한 것입니다. Excel 매크로의 시작 부터 차근 차근 설명하고 있으므로 이전에 Excel 매크로에 대한 경험이 없더라도 쉽게 따라 오실수 있습니다. Excel 매크로란? Excel "매크로"와 "VBA"라는 용어를 들어 보셨을 겁니다. 간단히 말해서 둘은 같습니다. Excel 매크로는 Excel에 기본 제공되는 프로그래밍 언어 VBA를 나타냅니다. 일반적으로 VBA를 처음 접하는 사람은 매크로 라는 용어 를 사용하고 익숙해지면 VBA 라는 용어를 사용합니다. 결론은 하나를 가리키는 다른 이름일 뿐입니다. VBA는 무엇인가..
[VBA] '고급 필터' 완벽 가이드 들어가며 엑셀에는 특정 범위 대상으로 원하는 조건에 맞는 데이터를 추출할 수 있는 기능을 제공하고 있습니다. 이런 기능을 '필터'라고하며 간단하고 쉽게 적용할 수 있는 '자동 필터'와 복잡하지만 세부적이면서 여러 조건을 지정할 수 있는 '고급 필터'가 있습니다. 이번 포스트에서는 '고급 필터'가 무엇인지, 엑셀에서 고급 필터를 사용하기 위해서는 어떻게 해야하는지 살짝 살펴 본 후, VBA 스크립트를 이용해 고급 필터를 사용하는 법에 대해 중점적으로 알아 보도록하겠습니다. 고급 필터 퀵 가이드 Task Cell formula Examples where true 특정 단어 포함하는 문자열 선택 Pea ="Pea" ="*Pea*" Peach, Pea, Appear 특정 단어 포함 하지 않는 문자열 선택 ="*..
[VBA] 배열 완벽 가이드 이 포스트는 Excel Macro Mastery 사이트의 'Excel VBA Array – The Complete Guide(by Paul Kelly)'의 내용을 다시 정리한 것입니다. 이번 포스트에서는 엑셀 VBA의 배열(array)에 대해 다룹니다. 들어가며 본 포스트는 Excel VBA 프로그래밍의 아주 중용한 부분인 '배열(Array)'에 대해 자세히 설명 합니다. 먼저 배열이 정확히 무엇인지, 왜 필요한지 부터 살펴 보고 VBA에서 배열을 사용하기 위해 알아야 할 지식들에 대해 설명합니다. 본 포스트는 VBA를 사용하기 위해 기본적인 VBA 프로젝트 정도는 띄울 수 있는 것을 가정하고 작성 되었습니다. 만일 제가 지금 무슨 말을하고 있는지 이해가 가지 않으신 분이라면 [여기]에서 VBA의 기본적..
[C++20] 당신이 모듈(module)을 써야만 하는 이유 들어가며 C++의 모듈(module)은 concepts, ranges, coroutine과 더불어 'Big Four'이라고 불려지며 C++20 스펙에 추가된 네 가지 주요 요소 중에 하나다. 모듈은 기존 헤더 파일을 대체할 수 있을 뿐만 아니라, 컴파일 시간 개선, 매크로 격리(macro isolation, 용어가 생소하지만 뒤에 설명이 나온다)등을 제공한다. 간단하게 정리하면 #include 전처리 방식을 대신할 수 있는 새로 도입된 개념으로써 java의 package나 C#의 namespace와 동일한 역할을 한다. 모듈의 도입으로 C++에 어떠한 변화가 생겼는지 알아 보기 위해 우리는 기존 C++은 어떤 모습이었는지 먼저 살펴 볼 필요가 있다. 기존 C++의 구조를 보기 위해 그 유명한 "Hello..
[Unity] 쉐이더(Shader) 기초 들어가며 스프라이트를 클릭하면 외곽선을 하이라이트 시켜 선택되었다고 인지할 수 있는 기능을 만들고 싶었는데, 유니티에서 이런 기능을 만들려면 쉐이더를 써야 한다고 한다. 필자는 프로그래머로 오래 일을 해오긴 했지만 쉐이더 사용에는 전혀 문외한인지라 쉐이더를 공부하면서..아니다 공부라는 단어를 사용하기에는 너무 깊게 들어가지는 않을거라 '공부'라는 단어 보다는 기존 쉐이더를 분석하고 사용하는 방법을 알아간 과정을 기록하도록 하겠다. 쉐이더란? 화면에 출력할 픽셀의 위치와 색상을 계산하는 함수 쉐이더란 "화면에 출력할 픽셀의 위치와 색상을 계산하는 함수"라고 [여기]에서 쉽게 정의를 내리고 있다. 쉐이더는 크게 버텍스 쉐이더(vertex shader)와 픽셀 쉐이더(pixel shader)로 나뉘어진다. 버..
[Unity] Physics.Raycast 완벽 가이드 들어가며 Unity의 Physics.Raycast는 직선을 씬에 투영하여 대상에 적중되면 true를 리턴하는 물리 함수다. Raycast 함수는 캐스팅 성공 실패에 따른 결과만 리턴하는 간단한 형태에서 부터 대상과 Ray의 충돌에 관련된 자세한 정보를(직선과 객체의 교차 정보. 거리, 위치, 캐스팅에 검출 된 객체의 Transform에 대한 참조 등) 리턴하는 다양한 버전이 제공 되고 있다. 이번 포스트에서는 Raycast 함수를 사용하기 위해 알아야할 필수적인 요소들을 살펴 보는 시간을 갖도록 하겠다. Unity에서 Raycast를 사용하는 법 Unity 2020.3 버전 기준으로 Physics.Raycast는 아래와 같이 다양한 버전으로 오버로드 되어 제공되고 있다. bool Raycast(Vecto..
[C++20] 모듈(module) 모듈(module) 이란? C++20 이전의 C++에서는 필요한 함수 또는 클래스를 불러오기 위해 #include 전처리문을 이용해 왔다. 이런 헤더 파일 방식의 문제는..많지만 그 중에 필자가 가장 크리티컬하게 생각하는 부분은 #include 전처리문을 가리키고 있던 파일의 내용 그대로 치환해버려 헤더에 있는 필요하든 필요하지 않든 상관 없이 정의 되어있는 모든 기능을 포함하게 된다는 것이다. 예를 들어 cmath 헤더 파일에서 정작 내가 필요한 기능은 acos함수 하나 뿐이지만, acos를 사용하기 위해서 나는 헤더에 정의된 모든 함수들을 인클루드하고 컴파일 해야만 한다. 이미 현재 다른 언어들에서는 필요한 기능만을 가져 올 수 있는 기능을 제공하고 있지만 C++은 이번 C++20 스펙의 module..
[Unity] Physics.Simulate를 이용한 네트워크 동기화 들어가며 네트워크 게임에서 서버와 클라이언트간의 네트워크 전송 지연(transmission delay)은 이 세상에 물리 법칙이 적용되는한 피할 수 없는 사실이다. 플레이어가 액션을 취한 뒤 서버의 시뮬레이션을 거쳐 다른 플레이어들에게 전파되기 까지는 항상 지연이 수반 된다. 위 그림에서 클라이언트 A에서 전송한 패킷이 서버에서 처리를 거쳐 클라이언트 B에게 전달 되기 까지 100ms가 필요했다. 따라서 클라이언트 B에서 볼 수 있는 클라이언트 A의 최근 모습은 아무리 빨라도 100ms 이전의 모습 밖에는 볼 수 없다. 다시 한번 말하지만 네트워크 지연은 절대 피할 수 없는 물리적 한계이고, 길다면 길고 짧다면 짦은 온라인 게임의 역사속에 이 문제를 해결하기 위한 많은 방법들이 제시되었다. 이번 포스트에..
[Linux] 데몬(Daemon) 프로세스 만들기 데몬(daemon)이란? '데몬(daemon)' 프로세스는 리눅스 운영 체제서 사용하는 프로세스의 일종으로써, 시스템 시작이 시작할 때 그 생명을 시작하여, 우리가 알지 못하는 백그라운드에서 자신의 할 일을 묵묵히 행하다 시스템과 함께 그 생명을 다한다(대충 컴퓨터 켜면 자동으로 실행해서 끌 때까지 종료되지 않는다는 뜻). 이 페이지에서는 데몬의 특징을 살펴 보고 간단한 데몬 프로세스를 만들어 보도록 하겠다. 참고로 윈도우에서는 '서비스'라는 데몬 프로세스와 비슷한 역할을 하는 것이 있다. 윈도우 '서비스'에 대한 설명은 본 포스트 맨 아래 부록으로 추가 되어있다. 데몬(daemon) 프로세스의 특징 일반적으로 Daemon을 단순히 시스템 백그라운드에서 돌아가고 있는 프로세스라 생각하기 쉽다. 아래의 화..

반응형