Se aplica a
Project Server 2010

Síntomas

El número de registros de la tabla de sombra que se generan en un aumento del campo indicador de empresa rápidamente en Microsoft Project Server 2010. Este problema provoca problemas de rendimiento.

Solución

Para resolver este problema, aplique el paquete de hotfix siguientes:

2597138 descripción del paquete de revisiones de Project Server 2010 (archivo Pjsrvwfe-x-none.msp): 28 de febrero de 2012

Más información

Esta revisión administra el número de registros de la tabla de sombra para que el número de registros no aumente demasiado. Cada vez que abra o guarde un plan de proyecto en Project Professional después de aplicar la revisión en el servidor de Project server, los registros de la tabla de sombra que sean relevantes para el proyecto se limpian. Si desea limpiar los registros de la tabla de sombra de forma masiva, puede utilizar la siguiente secuencia de comandos. Antes de ejecutar la secuencia de comandos, asegúrese de que lea los siguientes puntos:

  • Realizar una copia de seguridad de la base de datos de Project server antes de ejecutar la secuencia de comandos.

  • Para evitar problemas de contenido inesperado de la base de datos, detenga el servicio de cola en los servidores de aplicaciones del proyecto cuando no se ha producido ninguna actividad en los servidores durante varias horas.

  • Validar la secuencia de comandos en un entorno de desarrollo mediante la copia de seguridad actual de la base de datos de Project server.

  • El tiempo que tarda en completarse la secuencia de comandos en el entorno de desarrollo. El tiempo necesario para completar la secuencia de comandos de eliminación depende del servidor SQL y el número de los registros que han de ser eliminados. Asegúrese de que la secuencia de comandos se ha completado en el tiempo planificado.

Para limpiar los registros de la tabla de sombra de forma masiva, siga estos pasos:

  1. Ejecute el siguiente script en el proyecto y la publicación de bases de datos y recuperar el espacio libre en las bases de datos:

    --Clean up       MSP_TASK_CUSTOM_FIELD_VALUES_SHADOW       IF object_id('tempdb..#TempTaskCFShadow') IS NOT NULL       BEGIN        drop table #TempTaskCFShadow        END      CREATE table #TempTaskCFShadow (pid uniqueidentifier, tid uniqueidentifier, revCount int, mdpid uniqueidentifier)      INSERT #TempTaskCFShadow (pid, tid, revCount, mdpid)      SELECT PROJ_UID, TASK_UID, MAX(DELETED_REV_COUNTER), MD_PROP_UID                        FROM MSP_TASK_CUSTOM_FIELD_VALUES_SHADOW                        GROUP BY PROJ_UID , TASK_UID, MD_PROP_UID       DELETE       FROM MSP_TASK_CUSTOM_FIELD_VALUES_SHADOW         FROM MSP_TASK_CUSTOM_FIELD_VALUES_SHADOW as originalTable, #TempTaskCFShadow AS newtable      where originalTable.MD_PROP_UID = newtable.mdpid AND      originalTable.PROJ_UID = newtable.pid AND       originalTable.TASK_UID = newtable.tid AND      originalTable.DELETED_REV_COUNTER <> newtable.revCount        DROP TABLE #TempTaskCFShadow--Clean up MSP_ASSN_CUSTOM_FIELD_VALUES_SHADOW       IF object_id('tempdb..#TempAssnCFShadow') IS NOT NULL       BEGIN        drop table #TempAssnCFShadow        END      CREATE table #TempAssnCFShadow (pid uniqueidentifier, asid uniqueidentifier, revCount int, mdpid uniqueidentifier)      INSERT #TempAssnCFShadow (pid, asid, revCount, mdpid)      SELECT PROJ_UID, assn_uid, MAX(DELETED_REV_COUNTER), MD_PROP_UID                        FROM MSP_ASSN_CUSTOM_FIELD_VALUES_SHADOW                        GROUP BY PROJ_UID , ASSN_UID, MD_PROP_UID       DELETE       FROM MSP_ASSN_CUSTOM_FIELD_VALUES_SHADOW        FROM MSP_ASSN_CUSTOM_FIELD_VALUES_SHADOW as originalTable, #TempAssnCFShadow AS newtable      where originalTable.MD_PROP_UID = newtable.mdpid AND      originalTable.PROJ_UID = newtable.pid AND       originalTable.ASSN_UID= newtable.asid AND      originalTable.DELETED_REV_COUNTER <> newtable.revCount        DROP TABLE #TempAssnCFShadow--Clean up       MSP_PROJ_RES_CUSTOM_FIELD_VALUES_SHADOW      IF object_id('tempdb..#TempProjResCFShadow') IS NOT NULL       BEGIN        drop table #TempProjResCFShadow        END        CREATE table #TempProjResCFShadow (pid uniqueidentifier, resid uniqueidentifier, revCount int, mdpid uniqueidentifier)      INSERT #TempProjResCFShadow (pid, resid, revCount, mdpid)      SELECT PROJ_UID, RES_UID, MAX(DELETED_REV_COUNTER), MD_PROP_UID                        FROM MSP_PROJ_RES_CUSTOM_FIELD_VALUES_SHADOW                        GROUP BY PROJ_UID , RES_UID, MD_PROP_UID       DELETE       FROM MSP_PROJ_RES_CUSTOM_FIELD_VALUES_SHADOW         FROM MSP_PROJ_RES_CUSTOM_FIELD_VALUES_SHADOW as originalTable, #TempProjResCFShadow AS newtable      where originalTable.MD_PROP_UID = newtable.mdpid AND      originalTable.PROJ_UID = newtable.pid AND       originalTable.RES_UID = newtable.resid AND      originalTable.DELETED_REV_COUNTER <> newtable.revCount      DROP TABLE #TempProjResCFShadow --Clean up MSP_PROJ_CUSTOM_FIELD_VALUES_SHADOW       IF object_id('tempdb..#TempProjCFShadow') IS NOT NULL       BEGIN        drop table #TempProjCFShadow        END        CREATE table #TempProjCFShadow (pid uniqueidentifier, revCount int, mdpid uniqueidentifier)      INSERT #TempProjCFShadow (pid, revCount, mdpid)      SELECT PROJ_UID, MAX(DELETED_REV_COUNTER), MD_PROP_UID                        FROM MSP_PROJ_CUSTOM_FIELD_VALUES_SHADOW                        GROUP BY PROJ_UID , MD_PROP_UID          DELETE       FROM MSP_PROJ_CUSTOM_FIELD_VALUES_SHADOW         FROM MSP_PROJ_CUSTOM_FIELD_VALUES_SHADOW as originalTable, #TempProjCFShadow AS newtable      where originalTable.MD_PROP_UID = newtable.mdpid AND      originalTable.PROJ_UID = newtable.pid AND       originalTable.DELETED_REV_COUNTER <> newtable.revCount        DROP TABLE #TempProjCFShadow
  2. Ejecute el siguiente script en la base de datos publicada después de ejecutar la secuencia de comandos del paso 1 en el proyecto y la publicación de bases de datos:

    --Clean up MSP_RES_CUSTOM_FIELD_VALUES_SHADOW      IF object_id('tempdb..#TempResCFShadow') IS NOT NULL       BEGIN        drop table #TempResCFShadow        END        CREATE table #TempResCFShadow (resid uniqueidentifier, revCount int, mdpid uniqueidentifier)      INSERT #TempResCFShadow (resid, revCount, mdpid)      SELECT RES_UID, MAX(DELETED_REV_COUNTER), MD_PROP_UID                        FROM MSP_RES_CUSTOM_FIELD_VALUES_SHADOW                        GROUP BY RES_UID, MD_PROP_UID       DELETE       FROM MSP_RES_CUSTOM_FIELD_VALUES_SHADOW        FROM MSP_RES_CUSTOM_FIELD_VALUES_SHADOW as originalTable, #TempResCFShadow AS newtable      where originalTable.MD_PROP_UID = newtable.mdpid AND      originalTable.RES_UID = newtable.resid AND      originalTable.DELETED_REV_COUNTER <> newtable.revCount        DROP TABLE #TempResCFShadow

Estado

Microsoft ha confirmado que se trata de un problema de los productos de Microsoft que se enumeran en la sección "Aplicable a".

¿Necesita más ayuda?

¿Quiere más opciones?

Explore las ventajas de las suscripciones, examine los cursos de aprendizaje, aprenda a proteger su dispositivo y mucho más.