작성
·
293
0
안녕하세여
다대다 관계 조인시 잘 되지 않아 질문합니다.
user < - > product의 관계를 다대다 관계로 설정하였습니다.
데이터베이스 셋팅은 다 되어 있는 상태입니다.
user <-> user_product <-> product
user에서 include메소드를 이용하여 product랑 조인을 할려고 합니다.
get: async((req, res)) {
const user = await User.findAll({
include: [{
model: Product
}]
console.log(user); // 확인시 User테이블 데이터만 나옵니다.
})
}
이렇게만 하면 조인이 될 줄알았는데 확인 시 콘솔로 확인 시 유저정보만 나옵니다.
제일마지막에 Products라는게 있긴 있는데 빈배열로 나옵니다.
강의 중 중간테이블(조인테이블)은 따로 건드릴 필요없다고 말씀을 하신거 같은데 그러면 이 중간테이블 값은 알아서 조인을 할때 알아서 시퀄라이즈에서 값을 만들어 주는건가요?
무엇이 잘못된것일까요??
답변 7
0
0
0
0
제가 디비 설계를 잘못한거 같다는 생각이 듭니다.
Product의 테이블에는 어떤컬럼이 있냐면
상품정보
이미지
즐겨찾기(true/false)
상세 내용
등등
이 있고 다대다 관계를 맺은 이유가 즐겨찾기 한 유저를 찾을려고 두 테이블간에 다대다 관계를 맺었습니다.
여기서 즐겨찾기란 찜을 한다고 생각하시면 됩니다.
어떤 유저가 물건을 브라우저에서 찜했을때 해당물건정보를 서버로 넘겨주고 session을 이용하여 해당 user를 데이터베이스에서 찾고...... 여기서 막히네요
지금 드는생각은
user- like라는 테이블을 하나더 생성하고
user product라는 컬럼을 만들어서 해당 사용자가 찜버튼을 클릭하면 클라이언트에서 product정보를 넘겨주고 서버에서는 user-like 테이블에 user와 product(클라이언트에서 넘겨준 정보)를 데이터베이스 에 저장한다.
그럼 3개의 테이블은 굳이 관계가 따로 없을거 같긴합니다.
제 생각이 어떤가요?
감사합니다.
0
user_products 테이블이 비어있다는 것은 user에 products를 추가하거나 products에 user를 추가할 때 제대로 안 되어있다는 뜻입니다.
0
어떤걸 확인 해보라는 말씀이신가요?
지금 현재 확인 시 user_products 테이블은 정상적으로 생성이 되어 있고 텅텅 비어있는 상태입니다.
빠른답변 감사합니다.
0
워크벤치를 통해 user_products 테이블을 확인해보세요. 보통 include에서 제대로 안 되는 경우 오타가 없다면 등록할 때 제대로 등록되지 않은 경우가 대다수입니다.