2014-04-20 4 views
-1

다운로드 영역이 포함 된 웹 사이트가 있습니다.이 섹션에 새 파일이 업로드되면 사용자에게 알리고 싶습니다.새 레코드 사용자에게 알리기

나는 이것을 수행하는 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_downloadsviewed_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_downloadsviewed_events 테이블에 추가 될 것입니다 - INSERT가

하는 접근 방식을 무시 더 낫겠 니?

+0

이해할 수 없습니다 새로운 파일이 다운로드 영역에 업로드 될 때 사용자에게 알리시겠습니까? 아니면 파일을 다운로드 한 사람의 수를 계산 하시겠습니까? –

+0

죄송합니다. 사용자에게 새 파일이 업로드되어 다운로드 할 수 있음을 알리는 것입니다. –

답변

0

질문을 잘 이해하면 가장 좋은 해결책은 ViewsCount이며 사용자가 아이템을 다운로드 할 때마다 업데이트되며이 alos가 업데이트됩니다. 이 계정을 가장 많이 다운로드 한 파일을 얻으려고 할 때 간단한 선택 문을 사용하여 가장 좋은 방법이 될 수있는 가장 좋은 솔루션이 될이 계정의 다운로드 파일을 얻을 수 있습니다.

+1

답변 해 주셔서 감사합니다. 미안해, 내 질문에 옳은 말을해서는 안된다.Facebook에 누군가가 그룹에 게시했음을 알리는 것과 유사하게 실제로 다운로드 할 필요가없는 사용자가 –

+0

일 때 트리거 또는 기타 무언가를 만들 필요가 없다는 것을 알려주는 새로운 다운로드 또는 이벤트가 추가되거나 다운로드되었음을 사용자에게 알리는 것입니다. 사용자가 업로드를 완료 할 때 사용자에게 통보해야하는 동일한 단계에서 파일을 업로드 할 때 동일한 트랜잭션에서 새 파일이 업로드되었다는 알림을 사용자에게 보내면됩니다. –

관련 문제