해결된 질문
작성
·
66
0
실습 중에 댓글 작성하려고 하는데 오류가 발생해서 오류 로그를 보다가 sqlMessage 로 "Unknown column 'commenter' in 'field list'", 라는 문구를 봤습니다.
따로 commenter 라는 필드를 만드신건 못본거같은데 제가 강의를 흘려 들은건지 잘 모르겠습니다.
근데 이상한건, 맨 처음에 실행하고 댓글을 작성할땐 댓글이 작성이 되고, MySQL 에 들어가서 comment 테이블을 확인해보면 댓글이 들어가긴 했습니다.
근데 두번째 댓글 작성시도부터 오류가 발생했습니다.
답변 9
1
참고 코드 링크 감사합니다.
제 코드와 비교하면서 봤는데, 아무 문제 없었습니다.
근데 associate 함수를 index 에서 사용할때 오타가 있었습니다 죄송해요 ㅠㅠ
오타 수정 후 문제 해결되었습니다.
도움주셔서 감사합니다.
0
0
0
0
안녕하세요, 인프런 AI 인턴입니다. 한태현님.
질문해주신 내용을 보면, Sequelize를 사용하면서 commenter라는 컬럼과 관련된 이슈가 발생한 것 같습니다. 이 문제는 일반적으로 다음 두 가지 중 하나 때문에 발생할 수 있습니다:
컬럼의 미생성: commenter라는 컬럼이 comments
테이블에 실제로 존재하지 않을 때 이와 같은 오류가 발생합니다. 처음에는 테이블의 생성이나 컬럼의 정의가 잘못되었을 가능성이 있습니다.
모델 정의 미비: Sequelize 모델에서 commenter 컬럼이 정의되지 않았을 수 있습니다. 이 경우 comment
모델 정의에서 commenter
를 명시적으로 추가해야 합니다.
이와 관련된 유사한 질문과 답변이 이미 있는지 확인해보았으며, 다음 두 개의 게시물이 도움을 줄 수 있을 것 같습니다:
commenter오류: 여기서는 Unknown column 'Comment.commenter' in 'field list'
오류에 대한 처리 방법을 논의하고 있습니다. 특히, 테이블 생성과 시퀄라이즈 모델 간의 불일치로 인한 문제를 설명합니다.
시퀄라이즈 모델 생성 질문드립니다: 이 게시물에서는 테이블 컬럼을 직접 생성하는 방법과 외래키 설정에 관한 상세한 설명을 다루고 있습니다.
위 질문과 답변을 참고하시면서, 문제가 되는 comment
모델 및 테이블을 한번 확인하고, 필요시 테이블을 삭제 후 모델을 다시 정의 및 생성하여 문제를 해결할 수 있을 것입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
user 테이블의 comment는 상관없고요. comment 테이블에 userId가 있으면 안 됩니다. commenter가 있어야 하고요.
https://github.com/ZeroCho/nodejs-book/tree/master/ch7/7.6/learn-sequelize/models
이 링크 보고 코드 수정하세요. 테이블 전부 제거 후에 다시 생성하시고요.