다운로드 영역이 포함 된 웹 사이트가 있습니다.이 섹션에 새 파일이 업로드되면 사용자에게 알리고 싶습니다.새 레코드 사용자에게 알리기
나는 이것을 수행하는 2 가지 방법을 생각해 보았습니다.
첫 번째는 사용자가 마지막으로 이벤트를 방문하고 데이터베이스 테이블에 페이지를 다운로드 한 시간 &을 저장하는 것입니다. 스키마는 다음과 같이 보일 것입니다 :
Table `account_page_visits`:
page_id INT NOT NULL,
account_id INT NOT NULL,
last_visited DATETIME NOT NULL;
다운로드 테이블과 이벤트 테이블도 있습니다. 이 테이블에는 레코드가 테이블에 추가 된 날짜와 시간을 저장하는 date_added
열이 있습니다.
데이터베이스 (내 navigation
테이블에 저장 됨)에서 내 링크를 가져 오는 시점에서 각 링크를 확인하고 링크가 다운로드 또는 이벤트 인 경우 다운로드 또는 이벤트 수를 계산합니다 (date_added
) last_visited
현재 사용자의 페이지 시간.
이것은 실제로 나는 순간에 구현하는 방법입니다,하지만 난 문제가 발견 : 다운로드 또는 이벤트의 수를 데이터베이스에서 반환된다
Downloads (다운로드) 및 이벤트 페이지를 하위 페이지로 분할 제한을 페이지 당 20 개. 현재 알림 방법은 사용자가 이벤트 또는 다운로드 페이지를 방문하면 last_visited
시간이 새 다운로드/이벤트 중 date_added
보다 커서 모든 새로운 다운로드 또는 이벤트를 효과적으로 보았다고 가정합니다. 사용자가 다운로드 페이지 1을 방문한 다음 다른 페이지로 이동하는 경우 다운로드가 20 회 밖에 없었음에도 다운로드 알림이 더 이상 표시되지 않습니다.
두 번째 방법은이 문제를 해결하지만, 오랫동안 나에게 호흡 보인다 : 대신 account_page_visits
테이블의
viewed_downloads
및
viewed_events
테이블을 가질 것이다. 여기에는 이벤트/다운로드 ID와 계정 ID가 포함됩니다. 레코드가
viewed_downloads
또는
viewed_events
에 존재하는지 확인하여 보이지 않는 다운로드 수/이벤트 수를 얻습니다. 뭔가 같은 :
SELECT COUNT(1) FROM `downloads` d
WHERE NOT EXISTS (
SELECT 1 FROM `viewed_downloads` vd
WHERE vd.download_id = d.id
AND vd.account_id = userAccountId
)
기록은 다운로드/이벤트는 사용자가 SELECT의 어떤 종류의 다운로드/이벤트 페이지를 방문 할 때 선택 될 때 viewed_downloads
및 viewed_events
테이블에 추가 될 것입니다 - INSERT가
하는 접근 방식을 무시 더 낫겠 니?
이해할 수 없습니다 새로운 파일이 다운로드 영역에 업로드 될 때 사용자에게 알리시겠습니까? 아니면 파일을 다운로드 한 사람의 수를 계산 하시겠습니까? –
죄송합니다. 사용자에게 새 파일이 업로드되어 다운로드 할 수 있음을 알리는 것입니다. –