44,000원
다른 수강생들이 자주 물어보는 질문이 궁금하신가요?
- 미해결[C#과 유니티로 만드는 MMORPG 게임 개발 시리즈] Part5: 데이터베이스
각 연도별 최고의 홈런왕
을 찾아보는데 SELECT * FROM ( SELECT *, ROW_NUMBER() OVER (PARTITION BY yearID ORDER BY HR DESC) AS ranking FROM batting ) AS yearTableWHERE ranking = 1ORDER BY yearID DESC; FROM 이후에 AS로 이름을 지어주지 않으니 오류가 나는데 이름이 꼭 필요한가요?
- 미해결[C#과 유니티로 만드는 MMORPG 게임 개발 시리즈] Part5: 데이터베이스
Hash조인을 사용시 데이터가 엄청나게 많다면
잘 사용하는 쿼리가 아닐경우 해시조인을 사용할 때 양쪽 다 데이터가 많아서 HashTable bucket 안의 데이터도 많아졌다고 가정했을 때 NL을 사용하면 엄청난 비효율을 보여줄테고 Merge를 사용하면 데이터가 너무 많아 정렬에 비용을 많이 사용하게 될텐데 이렇게 되면 Hash조인을 사용하는게 더 좋은 선택인가요? 아니면 데이터를 정렬해주고 Merge조인을 사용해야 하는건가요?
- 미해결[C#과 유니티로 만드는 MMORPG 게임 개발 시리즈] Part5: 데이터베이스
데이터가 많을 때 Hash 를 사용?이 이해가 잘 안됩니다
join할 데이터베이스 양쪽 다 데이터가 많다면 Hash도 비용이 많이들어 효율이 낮아지는게 아닌가요? 만약 이럴땐 어떤 조인을 사용해야 할까요? NL을 사용하면 엄청난 비효율일 것 같고 Merge를 사용하기엔 데이터가 너무 많고 이래도 그냥 Hash를 사용하는것이 셋중에서 더 좋은 방법인가요?
- 미해결[C#과 유니티로 만드는 MMORPG 게임 개발 시리즈] Part5: 데이터베이스
INDEX - 트리 소소질문
INDEX를 설정해 준다는건.. 데이터가 삽입될때 트리가 적당한 위치에 데이터를 저장하고 [ 트리의 루트에서 '왼오왼왼오'의 방향으로 가면 데이터가 있다. ] 라고 말하는 것과 비슷한가요?
- 미해결[C#과 유니티로 만드는 MMORPG 게임 개발 시리즈] Part5: 데이터베이스
NON-CLUSTERED 를 잘 모르겠습니다
1. CLUSTERED 는 영한 사전처럼 순서대로 저장된다고 하셨는데 그러면 DB에 INSERT 하는 순서대로 저장되는건가요? 2. NON-CLUSTERED 를 사용하는 이유르 정확하게 모르겠습니다. accountName을 NON-CLUSTERED INDEX로 만들었는데 보통 닉네임을 정할때 중복없이 생성하게 되는데 이걸 색인으로 만들면 특정 이름을 찾는데에 모든 플레이어들의 이름을 다 비교하는게 아닌가요? 만약 그렇게 되면 색인을 넣든 안넣든 똑같은게 아닌가요? 예를들어서 플레이어를 찾을 때 [찾고싶은 플레이어 이름 = '플레이어 이름'] 이런식으로 찾는다 했을 때 굳이 색인이 필요한지 색인을 안하고 [찾고싶은 플레이어 이름 = '플레이어 이름'] 이런식으로 찾을 수는 없는건가요? 아니면 색인을 넣어줘야지 위처럼 찾는 기능이 가능한건가요?
- 미해결[C#과 유니티로 만드는 MMORPG 게임 개발 시리즈] Part5: 데이터베이스
sql파일?
[ 1 ] sql파일이 cs파일같은 거라고 볼 수 있나요? sql파일은 코드일 뿐이고 실행화면이 ↓이거라고 생각하면 될까요? [ 2 ]이 부분은 데이터 뿐이고 이거는 top1000만 빠르게 가져오는 쿼리를 만들어 실행하는 거고 아직은 모르지만 나중에 쿼리로 어떤 작업을 해야한다고 하면 sql파일을 따로 저장해 실행하거나? 하는걸로 이해하면 될까요?
- 미해결[C#과 유니티로 만드는 MMORPG 게임 개발 시리즈] Part5: 데이터베이스
키보드 질문
안녕하세요! 항상 강의 잘 듣고 있습니다. 현재 컴퓨터 사면 같이 딸려오는 번들키보드?를 쓰고 있습니다. 그 이전에도 불편하다고 느끼고 있었지만 DB수업을 들으면서 더 자주 대소문자 변환을 하면서 타자를 치다보니 손목도 아파오고 키도 힘을 많이 줘야 눌리는 피로감 같은게 느껴지더라구요. 강의 듣다보면 키보드 소리가 은은하게 굉장히 좋게 들리는데 혹시 추천하는 키보드가 있으실까요?
- 미해결[C#과 유니티로 만드는 MMORPG 게임 개발 시리즈] Part5: 데이터베이스
강의 영상 문의
안녕하세요 강사님. 강의 항상 잘 보고 있습니다. 다름이 아니라, 강의를 보는 중 간헐적으로 말씀이 뚝 끊기고 다음 장면으로 넘어가는 듯한 현상이 발생하는데요, 몇 몇 부분은 편집하신 부분이라는걸 알 수 있겠는데, 몇 몇 부분은 부자연스럽게 말이 중간에 끊기는 때도 있네요. 마찬가지로 편집된 곳이라 생각하고 넘기면 될까요? 감사합니다.
- 미해결[C#과 유니티로 만드는 MMORPG 게임 개발 시리즈] Part5: 데이터베이스
FIRST_VALUE랑 LAST_VALUE할 때 이해안되는 부분이 있어요
LAST_VALUE(salary) //salary의 마지막 값을 추출 OVER ( PARTITION BY playerID //playerid로 묶고 ORDER BY salary DESC //값이 큰 순서대로 정렬 ROWS BETWEEN CURRENT ROW AND UNBOUNDED FOLLOWING) //현재 줄부터 동일한 palyerID의 마지막 줄까지 범위를 지정 이렇게 해서 정렬 순서대로 가장 마지막의 값이 가장 작은 값이니까 가장 작은 값이 뽑혀오는 것까지는 이해되는데요 왜 ORDER BY로 큰 순서대로 정렬했는데 반대로 뒤집어져서 작은 숫자부터 출력되는지 이해가 안가요..
- 미해결[C#과 유니티로 만드는 MMORPG 게임 개발 시리즈] Part5: 데이터베이스
질문이 있습니다......
질문을 너무 자주하는 것같아 죄송합니다.... 근데 얜 왜 저한테 거짓말을 할까요......? 참고로 새로고침이나 껐다키기등은 여러번 해봤어요....
- 미해결[C#과 유니티로 만드는 MMORPG 게임 개발 시리즈] Part5: 데이터베이스
mac os jetbrains datagrip 사용 여부 문의
안녕하십니까 선생님. 윈도우 환경 이외에 나머지는 확인 안해보셨다 하셨지만 혹시나 해서 여쭤봅니다. mac os에서 공부해야 되서 그러는데 jetbrains의 datagrip으로 수업 들어도 괜찮을까요??
- 해결됨[C#과 유니티로 만드는 MMORPG 게임 개발 시리즈] Part5: 데이터베이스
복합 스플릿에서 3개 이상의 칼럼을 인덱스 설정하는 경우
복합 스플릿에서 3개 이상의 칼럼을 인덱스 설정하는 경우, 예를 들어 A,B,C를 걸었을 경우에 A만 검색할 때 2개의 칼럼에만 인덱스를 설정했을 때처럼 따로 A만 인덱스를 생성할 필요는 없지만, B,C의 경우에 각각을 검색해야할 때 각각 또 설정해줘야하나요? 이전에 Clustered가 영한 사전 형식으로 정렬이 되어있다고 하셨습니다. 이번 강의에서 인덱스를 걸면 Non-Clustered였는데, 복합 인덱스 순서에 관해 주의사항을 언급하실 때 페이지의 데이터가 정렬이 되어있었는데, 이 부분은 Non-Clustered이거나 Clustered이거나 모두 동일하게 정렬이 되나요?
- 해결됨[C#과 유니티로 만드는 MMORPG 게임 개발 시리즈] Part5: 데이터베이스
페이지 스플릿에 관하여
안녕하세요 강의를 듣던 중 궁금한점이 생겨 질문드리게되었습니다. 페이지 스플릿에 관하여 구글링해본결과 SQL SERVER의 경우 한 페이지의 최대 크기가 8KB라고 하는데요 질문 1) 만약 한 행(값)이 6KB를 차지하는 경우 다음 행 값을 추가한다면(똑같이 6KB) 페이지 스플릿이 일어나는것이 맞나요? (6+6 > 8) 질문 2) 만약 페이지 스플릿이 일어난다면 나머지공간(2KB)은 낭비하게 되나요? (8-6 = 2) 질문 3) 페이지를 못채우고 남는 공간을 줄이는 방법이 존재하나요?
- 해결됨[C#과 유니티로 만드는 MMORPG 게임 개발 시리즈] Part5: 데이터베이스
UNION에 관하여
UNION강의 4:30초에서 커리어 평균 연봉이 3000000 이상 "이거나" 12월에 태어난 선수를 구할 때 WHERE birthMonth = 12를 추가해주면 된다고 하셨는데 이 경우 커리어 평균 연봉이 3000000 이상 "이고" 12월에 태어난 선수를 구한 것 아닌가요?
- 해결됨[C#과 유니티로 만드는 MMORPG 게임 개발 시리즈] Part5: 데이터베이스
인덱스에 관하여 질문있습니다
안녕하세요 데이터베이스 인덱스 부분 강의를 듣던 중 궁금한 점이 생겨 질문드리게 되었습니다. 강의에서 직업이 5종류밖에 없다면 class 에 인덱스를 거는 것은 좋지 않다고 하셨는데 질문1) 여기서 좋지 않다는 것은 속도 향상이 있긴하나 효과가 적을뿐만 아니라 인덱스 자체의 크기(용량)이 커지기 때문이라고 이해하면 될까요? 질문2) 만약 직업별로 검색을 많이 하는 상황을 가정한다면 인덱스를 사용하는 것이 좋을까요? 읽어주셔서 감사합니다!
- 미해결[C#과 유니티로 만드는 MMORPG 게임 개발 시리즈] Part5: 데이터베이스
REDO, UNDO, ROLL BACK, ROLL FORWARD 에 관해
안녕하세요 Q1) 지금까지 이음동의어로 생각해왔는데 REDO = ROLL FORWARD UNDO = ROLL BACK 강의 마지막 결론에서 정리해주신 내용을 보니 또 다른 의미인 것 같아서 살짝 아리송 하네요 REDO 와 UNDO는 발자취(LOG)라고 보면 ROLL FORWARD나 ROLL BACK은 그 발자취를 따라 가는 행위를 말하는건가요? 마지막 질문으로 Part5 DB를 끝내봅니다 ㅎㅎ 감사합니다.
- 미해결[C#과 유니티로 만드는 MMORPG 게임 개발 시리즈] Part5: 데이터베이스
DBMS에서 Non Clustered Index를 사용하지 않는 이유
안녕하세요 강의 9분부터 시작되는, DMBS 자체적으로 Non Clustered Index를 사용하지 않는 이유가 궁금해서 질문드립니다. Q1) 다른 수강생분들이 올린 질문도 참고를 했는데 SELECT * FROM TestOrders WHERE CustomerID = 'QUICK'; 다음과 같은 sql문을 실행했을 때 DBMS가 INDEX를 사용하지 않고 SCAN을 하는 이유가 실제로 힙 테이블 내에 page가 메모리에 적재되지 않아 역효과가 발생할 수 있기에 라고 Full scan을 하는게 더 낫다고 하셨습니다. 마치 OS 가상메모리에서 page fault 가 일어나는 현상과 비슷하다고 생각을 합니다. 여기까지는 이해가 됐습니다. 다만 full scan이 더 효율적일 수 있을까? 하는 의구심이 듭니다. SELECT * FROM TestOrders WHERE CustomerID = 'QUICK'; 다음과 같은 sql문을 실행했을때 테이블의 데이터들도 인메모리 상태가 아니라면 물리 저장소에 접근후 메모리에 적재를 해야할텐데 과연 더 효율적일까 생각이 듭니다. 둘 다 메모리에 없다면 물리 저장소까지 다녀오는 건 비슷하다고 생각하는데 Full Scan이 조금 더 빠른건 Locality 때문인걸까요? Q2) 마지막 질문으로 Clustered Index와 비교해서 생각을 해보고싶습니다. Clustered Index는 Leaf Page가 곧 Data Page인데 이 Data Page도 메모리에 항상 적재되어 있을 것 같진 않습니다. 그럼에도 불구하고 Non Clustered Index보다 Select와 같은 Lookup이 빠른 이유는 Data Page내에 정렬된 데이터들과 이에따라 자연스레 형성된 Locality 때문인가요?
- 미해결[C#과 유니티로 만드는 MMORPG 게임 개발 시리즈] Part5: 데이터베이스
Non Clustered Index 동작방식
안녕하세요 :) Q1) Clustered Index 를 추가 한 뒤 Non Clustered Index의 변화를 살펴보면 PageID 값도 변하고 Heap Table이 사라짐에 따라 Heap RID도 변하게 됨을 확인했습니다. 궁금한 것은 강의 후반부 *18분 이후 내용입니다. Heap Table이 사라져도 Non Clustered Index를 사용해서 테이블에 저장된 데이터를 찾게 될텐데, 강의중 말씀하신 고유한 key 값이란 무엇인가요? UNIQUIFIER를 말씀하신걸까요? Q2-1) Clustered Index를 추가하면 Non Clustered Index의 구조가 변하는 것은 확인을 했는데 이는 OrderID라는 공통 Index가 있어서 가능한 일 인 것 같습니다. 공통 Index가 없이 Clustered Index를 추가해도 구조에 변화가 생기게 되는지 궁금합니다. Q2-2) 이어서 엉뚱한 질문을 드리면 Non Clustered Index 추가시 매커니즘을 보면 Non Clustered Index를 통해 고유한 Key 값 얻기 -> 고유한 Key 값으로 Clustered Page에서 Lookup 이와 같은 매커니즘인데 Non Clustered Index를 통해 얻은 고유한 Key값이 Clustered Page에서 데이터를 Lookup할 때 SCAN 가 아닌 SEEK을 한다는 보장이 있을까요? 다른 표현으로(맞는 표현일지는 모르겠지만...) Key값이 Clustered Page에서 Index로서의 역할을 제대로 할 수 있는건가요? 직전의 질문과도 연관이 있어보이는데 제 질문의 요점은 Non Clustered Index의 결과물을 Clustered Index의 Lookup에서 재사용하는 그림인데, 두 Index는 정의시 지정한 컬럼이 다른데 호환이 가능한지 궁금하네요. 감사합니다~
- 해결됨[C#과 유니티로 만드는 MMORPG 게임 개발 시리즈] Part5: 데이터베이스
Clustered Index에 DBCC PAGE 사용은 불가능한가요??
안녕하세요! 항상 빠른 답변 감사드립니다! Clustered Index에 대해 DBCC IND에서 Leaf Page 번호 확인 후 DBCC PAGE 로 실제 정보가 어떻게 들어가 있는지 보려고 시도했는데 "DBCC 실행이 완료되었습니다. DBCC에서 오류 메세지를 출력하면 시스템 관리자에게 문의하십시오."가 뜹니다. Non-clustered 와 다르게 clustered 인덱스의 leaf page에 담겨 있는 실제 데이터는 이런 쿼리로 볼 수 없는 건가요??
- 미해결[C#과 유니티로 만드는 MMORPG 게임 개발 시리즈] Part5: 데이터베이스
GROUP BY 질문
GROUP BY 강의 제일 마지막 예문에서 질문을 좀 바꾸어 각각의 년도에서 가장 많은 홈런을 친 팀을 추출하려면 어떤 문법을 이용해야 하나요?