practical debugging note
DB에서 페이지네이션 쿼리 다룰 때 디버깅 흐름
DB 작업에서 DB에서 문제를 확인할 때 볼 값과 검증 순서를 정리했습니다.
DB에서 메모 416 기준으로 보면, 로컬에서 괜찮았던 설정도 배포 환경에서는 다르게 보일 수 있다.
- DB에서 기준으로 보는 목표
- DB 관점의 현재 상태 파악
- 스키마 확인과 비교 기준
- DB 관점의 수정 순서
- 백업 확인과 확인 결과
DB에서 메모 416 기준으로 보면, 로컬에서 괜찮았던 설정도 배포 환경에서는 다르게 보일 수 있다.
핵심은 DB에서 메모 416에서 한 단어만 붙잡지 않고 데이터 계층 전체 흐름에서 원인을 좁히는 것이다. DB에서 메모 416에서는 재현 조건, 로그, 응답처럼 눈으로 확인할 수 있는 값을 먼저 모은다.
DB에서 기준으로 보는 목표
메모 416에서 중요한 건 DB에서 자체보다 재현 가능한 단서를 남기는 것이다. 메모 416의 DB에서 기준으로 보는 목표 기준으로 DATABASE_URL을 확인하면 다음으로 볼 범위가 확 줄어든다.
DB 관점의 현재 상태 파악
메모 416에서는 바로 수정하기 전에 마이그레이션부터 확인하면 불필요한 변경을 줄일 수 있다. 메모 416의 DB 관점의 현재 상태 파악에서 작은 확인이 쌓이면 원인 후보가 자연스럽게 줄어든다.
- 먼저 볼 값: 마이그레이션
- 같이 비교할 값: 정상일 때의 데이터 계층 상태
- 남겨둘 기록: 명령 출력, 응답 코드, 수정한 설정
스키마 확인과 비교 기준
메모 416에서 데이터 계층 작업은 로컬과 운영의 차이가 자주 숨어 있다. 메모 416의 스키마 확인과 비교 기준을 볼 때는 환경 차이까지 같이 적어두면 원인 추적이 쉬워진다.
npx prisma validate
npx prisma migrate status
DB 관점의 수정 순서
메모 416의 DB 관점의 수정 순서에서는 정상 상태를 먼저 정해두는 게 좋다. 그래야 메모 416에서 권한 결과가 맞는지 아닌지를 빠르게 판단할 수 있다.
백업 확인과 확인 결과
메모 416에서 데이터 계층 작업은 로컬과 운영의 차이가 자주 숨어 있다. 메모 416의 백업 확인과 확인 결과을 볼 때는 환경 차이까지 같이 적어두면 원인 추적이 쉬워진다.
- 원래 증상이 같은 조건에서 다시 나는지 확인한다.
- 로그나 응답에서 바뀐 부분을 한 줄로 설명해본다.
- 공개 화면, 빌드 결과, 실제 요청 중 하나로 마지막 확인을 한다.
DB 관점의 다음 액션 · 메모 416
메모 416의 DB 관점의 다음 액션 · 메모 416에서는 정상 상태를 먼저 정해두는 게 좋다. 그래야 메모 416에서 DATABASE_URL 결과가 맞는지 아닌지를 빠르게 판단할 수 있다.
마지막으로, DB에서 메모 416 기준에서는 해결 자체보다 어떤 값이 달라졌는지 설명할 수 있는 상태가 더 중요하다. 관련 기록을 짧게라도 남겨두면 다음 확인이 훨씬 빨라진다.