Как показать общее количество участников и пройденных тестов в каждом месяце и году для этого механизма тестирования? - PullRequest
0 голосов
/ 19 ноября 2011

Я занимаюсь разработкой простого веб-приложения, которое предоставляет пользователям тесты. Поскольку я новичок в мире ASP.NET, я слежу за тем, как создать серию видео для Quiz Engine на веб-сайте ASP.net. Мой дизайн базы данных похож на дизайн, используемый в этих видео. Это ссылка первого видео : http://www.asp.net/general/videos/lesson-11-building-a-quiz-engine-1[^]

У меня все отлично работает, но теперь я хочу разработать запрос, который поможет мне отобразить статистику для администратора, которая показывает:

  1. Общее количество участников и пройденных тестов за каждый месяц
  2. Общее количество участников и пройденных тестов за каждый год
  3. Общее количество тестов в системе

Чтобы прояснить последний пункт, я хочу, чтобы администратор увидел следующее:

Месяц Количество участников # пройденных тестов

15 ноября 6 10 октября 9

Другой пример:

год # количество участников пройденных тестов

2011 150 89

Я думаю, что-то вроде этого очень полезно знать об использовании системы и показать руководству, насколько эффективна система в компании.

Схема базы данных:

CREATE TABLE [dbo].[Quiz](
        [QuizID] [int] IDENTITY(1,1) NOT NULL,
        [Title] [varchar](max) NOT NULL,
        [Description] [varchar](max) NULL,
     CONSTRAINT [PK_Quiz] PRIMARY KEY CLUSTERED 
    (
        [QuizID] ASC
    )WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
    ) ON [PRIMARY]
    GO
    SET ANSI_PADDING OFF
    GO
    SET IDENTITY_INSERT [dbo].[Quiz] ON
    INSERT [dbo].[Quiz] ([QuizID], [Title], [Description]) VALUES (6, N'Safety', N'General Safety Test')
    INSERT [dbo].[Quiz] ([QuizID], [Title], [Description]) VALUES (7, N'my title', N'my description')
    INSERT [dbo].[Quiz] ([QuizID], [Title], [Description]) VALUES (9, N'General Safety Quiz2', N'Testing')
    INSERT [dbo].[Quiz] ([QuizID], [Title], [Description]) VALUES (10, N'General Safety Quiz3', N'Testing #2')
    SET IDENTITY_INSERT [dbo].[Quiz] OFF


    /****** Object:  Table [dbo].[Question]    Script Date: 11/17/2011 00:44:38 ******/

    CREATE TABLE [dbo].[Question](
        [QuestionID] [int] IDENTITY(1,1) NOT NULL,
        [Question] [varchar](max) NOT NULL,
        [Answer1] [varchar](max) NOT NULL,
        [Answer2] [varchar](max) NOT NULL,
        [Answer3] [varchar](max) NOT NULL,
        [Answer4] [varchar](max) NOT NULL,
        [CorrectAnswer] [tinyint] NOT NULL,
        [AnswerExplanation] [varchar](max) NULL,
        [QuestionOrder] [tinyint] NOT NULL,
        [QuizID] [int] NOT NULL,
     CONSTRAINT [PK_Question] PRIMARY KEY CLUSTERED 
    (
        [QuestionID] ASC
    )WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
    ) ON [PRIMARY]
    GO
    SET ANSI_PADDING OFF
    GO
    SET IDENTITY_INSERT [dbo].[Question] ON
    INSERT [dbo].[Question] ([QuestionID], [Question], [Answer1], [Answer2], [Answer3], [Answer4], [CorrectAnswer], [AnswerExplanation], [QuestionOrder], [QuizID]) VALUES (4, N'What is your name?', N'Mohammed ', N'Ali', N'Hassan', N'Husain', 1, N'My Name', 1, 6)
    INSERT [dbo].[Question] ([QuestionID], [Question], [Answer1], [Answer2], [Answer3], [Answer4], [CorrectAnswer], [AnswerExplanation], [QuestionOrder], [QuizID]) VALUES (7, N'What is the definition of Safety?', N'Being Safe', N'Being in danger', N'Be careful', N'be careless', 1, N'Nothing', 1, 9)
    INSERT [dbo].[Question] ([QuestionID], [Question], [Answer1], [Answer2], [Answer3], [Answer4], [CorrectAnswer], [AnswerExplanation], [QuestionOrder], [QuizID]) VALUES (8, N'What is the definition of Safety? ', N'Being Safe', N'Being Careless', N'Being Careful', N'Being in Dangerous', 1, N'Nothing to say', 1, 10)
    SET IDENTITY_INSERT [dbo].[Question] OFF
    /****** Object:  Table [dbo].[UserQuiz]    Script Date: 11/17/2011 00:44:38 ******/
    CREATE TABLE [dbo].[UserQuiz](
        [UserQuizID] [int] NULL,
        [QuizID] [int] NOT NULL,
        [DateTimeComplete] [smalldatetime] NOT NULL,
        [Score] [tinyint] NOT NULL,
        [Username] [nvarchar](256) NOT NULL
    ) ON [PRIMARY]
    GO
    INSERT [dbo].[UserQuiz] ([UserQuizID], [QuizID], [DateTimeComplete], [Score], [Username]) VALUES (NULL, 6, CAST(0x9F8F02D8 AS SmallDateTime), 100, N'SMP\ALMARHMS')
    INSERT [dbo].[UserQuiz] ([UserQuizID], [QuizID], [DateTimeComplete], [Score], [Username]) VALUES (NULL, 6, CAST(0x9F8F02E3 AS SmallDateTime), 50, N'SMP\ALMARHMS')
    INSERT [dbo].[UserQuiz] ([UserQuizID], [QuizID], [DateTimeComplete], [Score], [Username]) VALUES (NULL, 6, CAST(0x9F8F0333 AS SmallDateTime), 50, N'SMP\ALMARHMS')
    INSERT [dbo].[UserQuiz] ([UserQuizID], [QuizID], [DateTimeComplete], [Score], [Username]) VALUES (NULL, 7, CAST(0x9F8F0335 AS SmallDateTime), 100, N'SMP\ALMARHMS')

С помощью одного из ребят из этого замечательного сообщества я разработал один запрос, который показывает количество участников в каждой викторине. Это запрос:

SELECT
(SELECT COUNT(DISTINCT Q.UserName)  
 FROM dbo.UserQuiz Q  
 WHERE DateTimeComplete >= DATEADD(dd, -7, DATEADD(day, DATEDIFF(day, 0, GETDATE()), 0)))
 as ParticipantsLast7Days,
(SELECT COUNT(DISTINCT Q.UserName)  
 FROM dbo.UserQuiz Q  
 WHERE DateTimeComplete >= DATEADD(dd, -30, DATEADD(day, DATEDIFF(day, 0, GETDATE()), 0)))
 as ParticipantsLast30Days,
(SELECT COUNT(Q.QuizID)  
 FROM dbo.UserQuiz Q  
 WHERE Q.DateTimeComplete >= DATEADD(dd, -7, DATEADD(day, DATEDIFF(day, 0, GETDATE()), 0)))
 as QuizzesLast7Days,
(SELECT COUNT(Q.QuizID)  
 FROM dbo.UserQuiz Q  
 WHERE Q.DateTimeComplete >= DATEADD(dd, -30, DATEADD(day, DATEDIFF(day, 0, GETDATE()), 0)))
 as QuizzesLast30Days

Теперь мне нужно изменить его или перейти к новому запросу, который дает мне два вышеуказанных пункта. Как я могу это сделать?

1 Ответ

0 голосов
/ 13 января 2012

Месяц # Количество участников Taken Quizzes

select datename(month, datetimecomplete)+' '+ cast(count(distinct username) as varchar) +' '+ cast(count(distinct quizid) as varchar) Quizzes from userquiz group by datename(month, datetimecomplete)

Год # Количество участников # Taken Quizzes

select datename(year, datetimecomplete)+' '+ cast(count(distinct username) as varchar) +' '+ cast(count(distinct quizid) as varchar) Quizzes from userquiz group by datename(year, datetimecomplete)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...