2011-11-11 5 views

risposta

29

Lo script DDL è collegato da Elmah downloads page. Non è necessario trascinare l'albero dei sorgenti.

(perché non è in bundle con il NuGet mi sfugge)

+18

@Brettski: ho appena installato il progetto 'Elmah.Mvc' (v2.1.1) e non ha creato una cartella 'App_Readme' o alcuno script ddl. –

+1

Questa pagina non esiste più :( –

23

Ho trovato lo script in controllo del codice sorgente: https://code.google.com/p/elmah/source/browse/src/Elmah.SqlServer/SQLServer.sql

Eseguire lo script sul database che si utilizza per creare le strutture di database per Elmah.

+1

Potete correggere il collegamento e aggiungere un sommario? Le risposte di solo collegamento hanno poco valore. –

+0

Il file non esiste più! L'ultimo URL è https://bitbucket.org/project-elmah/main/downloads/ELMAH-1.2-db-SQLServer.sql – Wiil

0

Per uno scenario di codice prima migrazione, ho trovato l'articolo this molto utile.

Primo comando Add-Migration AddElmah in 'Console Gestione pacchetti'. Questo creerà un file nella cartella Migration. Questo file conterrà la classe AddElmah con le funzioni Up() e Down(). Sostituito queste due funzioni con codice qui sotto:

public override void Up() 
{ 
    Sql(@"CREATE TABLE [dbo].[ELMAH_Error] 
     (
      [ErrorId]  UNIQUEIDENTIFIER NOT NULL, 
      [Application] NVARCHAR(60) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL, 
      [Host]  NVARCHAR(50) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL, 
      [Type]  NVARCHAR(100) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL, 
      [Source]  NVARCHAR(60) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL, 
      [Message]  NVARCHAR(500) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL, 
      [User]  NVARCHAR(50) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL, 
      [StatusCode] INT NOT NULL, 
      [TimeUtc]  DATETIME NOT NULL, 
      [Sequence] INT IDENTITY(1, 1) NOT NULL, 
      [AllXml]  NTEXT COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL 
     ) "); 

    Sql("EXEC('ALTER TABLE [dbo].[ELMAH_Error] WITH NOCHECK ADD CONSTRAINT[PK_ELMAH_Error] PRIMARY KEY([ErrorId])')"); 

    Sql("EXEC('ALTER TABLE [dbo].[ELMAH_Error] ADD CONSTRAINT[DF_ELMAH_Error_ErrorId] DEFAULT(NEWID()) FOR[ErrorId]')"); 

    Sql(@"EXEC('CREATE NONCLUSTERED INDEX [IX_ELMAH_Error_App_Time_Seq] ON [dbo].[ELMAH_Error] 
     (
      [Application] ASC, 
      [TimeUtc]  DESC, 
      [Sequence]  DESC 
     )')"); 

    Sql(@"EXEC('CREATE PROCEDURE [dbo].[ELMAH_GetErrorXml] (@Application NVARCHAR(60), @ErrorId UNIQUEIDENTIFIER) AS 
      SET NOCOUNT ON 
      SELECT [AllXml] FROM [ELMAH_Error] WHERE [ErrorId] = @ErrorId AND [Application] = @Application')"); 

    Sql(@"EXEC('CREATE PROCEDURE [dbo].[ELMAH_GetErrorsXml] 
     (@Application NVARCHAR(60), @PageIndex INT = 0, @PageSize INT = 15, @TotalCount INT OUTPUT) 
     AS 
      SET NOCOUNT ON 
      DECLARE @FirstTimeUTC DATETIME 
      DECLARE @FirstSequence INT 
      DECLARE @StartRow INT 
      DECLARE @StartRowIndex INT 

      SELECT @TotalCount = COUNT(1) FROM [ELMAH_Error] WHERE [Application] = @Application 

      SET @StartRowIndex = @PageIndex * @PageSize + 1 

      IF @StartRowIndex <= @TotalCount 
      BEGIN 
       SET ROWCOUNT @StartRowIndex 

       SELECT @FirstTimeUTC = [TimeUtc], @FirstSequence = [Sequence] FROM [ELMAH_Error] 
       WHERE [Application] = @Application ORDER BY [TimeUtc] DESC, [Sequence] DESC 
      END 
      ELSE 
      BEGIN 
       SET @PageSize = 0 
      END 

      SET ROWCOUNT @PageSize 

      SELECT 
       errorId  = [ErrorId], 
       application = [Application], 
       host  = [Host], 
       type  = [Type], 
       source  = [Source], 
       message  = [Message], 
       [user]  = [User], 
       statusCode = [StatusCode], 
       time  = CONVERT(VARCHAR(50), [TimeUtc], 126) + ''Z'' 
      FROM [ELMAH_Error] error WHERE [Application] = @Application AND [TimeUtc] <= @FirstTimeUTC 
      AND [Sequence] <= @FirstSequence ORDER BY [TimeUtc] DESC, [Sequence] DESC FOR XML AUTO')"); 

    Sql(@"EXEC('CREATE PROCEDURE [dbo].[ELMAH_LogError] (@ErrorId UNIQUEIDENTIFIER, @Application NVARCHAR(60), @Host NVARCHAR(30), 
      @Type NVARCHAR(100), @Source NVARCHAR(60), @Message NVARCHAR(500), @User NVARCHAR(50), @AllXml NTEXT, @StatusCode INT, 
      @TimeUtc DATETIME) AS 

     SET NOCOUNT ON 

     INSERT INTO [ELMAH_Error] ([ErrorId], [Application], [Host], [Type], [Source], [Message], [User], [AllXml], [StatusCode], [TimeUtc]) 
     VALUES (@ErrorId, @Application, @Host, @Type, @Source, @Message, @User, @AllXml, @StatusCode, @TimeUtc)')"); 
} 

public override void Down() 
{ 
    Sql("EXEC('DROP PROCEDURE [ELMAH_GetErrorXml]')"); 
    Sql("EXEC('DROP PROCEDURE [ELMAH_GetErrorsXml]')"); 
    Sql("EXEC('DROP PROCEDURE [ELMAH_LogError]')"); 
    Sql("Drop table ELMAH_Error"); 
} 

Ora, quando si esegue il comando Update-Database in "Gestione Console Package", ELMAH_Error tavolo e relative procedure verranno creati nel database.