UPDATE: This issue is note related to the XML, I duplicated the table using an nvarchar(MAX) instead and still same issue. I will repost a new topic.
I have a table with about a million records, the table has an XML field. The query is running extremely slow, even when selecting just an ID. Is there anything I can do to increase the speed of this, I have tried setting text in row on, but SQL server will not allow me to, I receive the error "Cannot switch to in row text in table".
I would appreciate any help in a fix or knowledge that I seem to be missing.
Thanks
TABLE
/****** Object:  Table [dbo].[Audit]    Script Date: 08/14/2009 09:49:01 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE TABLE [dbo].[Audit](
    [ID] [int] IDENTITY(1,1) NOT NULL,
    [ParoleeID] [int] NOT NULL,
    [Page] [int] NOT NULL,
    [ObjectID] [int] NOT NULL,
    [Data] [xml] NOT NULL,
   [Created] [datetime] NULL,
CONSTRAINT [PK_Audit] PRIMARY KEY CLUSTERED 
(
    [ID] ASC
)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF,          ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
) ON [PRIMARY]
QUERY
DECLARE @ID int
SET @ID = NULL  
DECLARE @ParoleeID int
SET @ParoleeID = 158 
DECLARE @Page int
SET @Page = 2
DECLARE @ObjectID int
SET @ObjectID = 93 
DECLARE @Created datetime
SET @Created = NULL
SET NOCOUNT ON;
Select TOP 1 [Audit].* from [Audit]
where 
 (@ID IS NULL OR Audit.ID = @ID)  AND
 (@ParoleeID IS NULL OR Audit.ParoleeID = @ParoleeID)  AND
 (@Page IS NULL OR Audit.Page = @Page)  AND
 (@ObjectID IS NULL OR Audit.ObjectID = @ObjectID)  AND
 (@Created is null or(Audit.Created > @Created and Audit.Created < DATEADD (d, 1, @Created ))  )