REVISIÓN: Cuando utiliza las variables de cursor de Transact-SQL para realizar operaciones que tienen grandes iteraciones, pérdidas de memoria pueden producirse en SQL Server 2000

IMPORTANTE: Este artículo ha sido traducido por un software de traducción automática de Microsoft (http://support.microsoft.com/gp/mtdetails) en lugar de un traductor humano. Microsoft le ofrece artículos traducidos por un traductor humano y artículos traducidos automáticamente para que tenga acceso en su propio idioma a todos los artículos de nuestra base de conocimientos (Knowledge Base). Sin embargo, los artículos traducidos automáticamente pueden contener errores en el vocabulario, la sintaxis o la gramática, como los que un extranjero podría cometer al hablar el idioma. Microsoft no se hace responsable de cualquier imprecisión, error o daño ocasionado por una mala traducción del contenido o como consecuencia de su utilización por nuestros clientes. Microsoft suele actualizar el software de traducción frecuentemente.

Haga clic aquí para ver el artículo original (en inglés): 837957
Este artículo se ha archivado. Se ofrece "tal cual" y no se volverá a actualizar.
Error nº: 471233 (SQL Server 8.0)


Microsoft distribuye correcciones de SQL Server 2000 como un archivo descargable. Como las revisiones son acumulativas, cada versión nueva contiene todas las revisiones y las actualizaciones de software que se incluían con la actualización de software anterior de SQL Server 2000.
Síntomas
Cuando utilice las variables de cursor de Transact-SQL para realizar operaciones que tienen grandes iteraciones, puede observar el comportamiento siguiente:
  • El cliente que realiza las operaciones en el equipo que ejecuta SQL Server puede devolver errores de memoria insuficiente que son similares al siguiente:

    mensaje de error 1

    Msg 701: memoria del sistema insuficientes para ejecutar esta consulta.
    mensaje de error 2

    Msg 1204: El servidor de SQL no se puede obtener un recurso LOCK en este momento. Vuelva a ejecutar la instrucción cuando haya menos usuarios activos o pida al administrador del sistema para comprobar la configuración de bloqueos y memoria de SQL Server.
    mensaje de error 3

    Msg 17803: Memoria insuficiente disponible.
  • La respuesta del equipo que ejecuta SQL Server 2000 puede ser más lenta.
  • La instrucción FREEPROCCACHE de DBCC Transact-SQL no puede liberar la memoria o no puede borrar la caché de procedimiento. Este comportamiento puede producirse incluso cuando el cliente está desconectado del equipo que ejecuta SQL Server.
Causa
Este comportamiento se produce porque no se liberan los recursos que utilizan la variable de cursor.
Solución
Para evitar este problema, debe liberar los recursos que se asignan a las variables de cursor. Para ello, debe asegurarse de los siguientes:
  • Si utiliza una instrucción SET de Transact-SQL para establecer una variable de cursor, debe utilizar una instrucción DEALLOCATE Transact-SQL para liberar los recursos utilizados por el cursor cuando el cursor ya no es necesario.
  • Si utiliza una instrucción Transact-SQL OPEN para abrir una variable de cursor, debe utilizar una instrucción Transact-SQL CLOSE para liberar los recursos utilizados por el cursor cuando el cursor ya no es necesario.
Solución

Información de Service Pack

Para resolver este problema, consiga el Service Pack más reciente para Microsoft SQL Server 2000. Para obtener más información, haga clic en el número de artículo siguiente para verlo en Microsoft Knowledge Base:
290211Cómo obtener el Service Pack más reciente de SQL Server 2000

Información de revisiones

La versión en inglés de esta revisión tiene los atributos de archivo enumerados en la siguiente tabla u otros posteriores. Las fechas y horas de estos archivos aparecen en la hora universal coordinada (UTC). La información de los archivos se convertirá a la hora local cuando la vea. Para averiguar la diferencia entre hora UTC y la hora local, utilice la ficha zona horaria de la herramienta fecha y hora en el panel de control.
   Date         Time   Version            Size    File name   --------------------------------------------------------------------   31-May-2003  05:15  2000.80.818.0      78,400  Console.exe         27-Oct-2003  14:51  2000.80.873.0     315,968  Custtask.dll        30-Jan-2004  02:59  2000.80.911.0      33,340  Dbmslpcn.dll        24-Apr-2003  12:42                    786,432  Distmdl.ldf   24-Apr-2003  12:42                  2,359,296  Distmdl.mdf   29-Jan-2003  12:25                        180  Drop_repl_hotfix.sql   11-Sep-2003  13:56  2000.80.859.0   1,905,216  Dtspkg.dll          26-Aug-2003  06:46  2000.80.854.0     528,960  Dtspump.dll         23-Jun-2003  09:10  2000.80.837.0   1,557,052  Dtsui.dll           23-Jun-2003  09:10  2000.80.837.0     639,552  Dtswiz.dll          23-Apr-2003  13:21                    747,927  Instdist.sql   02-May-2003  12:26                      1,581  Inst_repl_hotfix.sql   30-Jan-2004  02:59  2000.80.911.0      90,692  Msgprox.dll         31-Mar-2003  12:37                      1,873  Odsole.sql   30-Jan-2004  02:59  2000.80.911.0      62,024  Odsole70.dll        30-Jan-2004  02:59  2000.80.911.0      25,144  Opends60.dll        30-Jan-2004  02:59  2000.80.911.0      57,904  Osql.exe            02-Apr-2003  09:45  2000.80.797.0     279,104  Pfutil80.dll        04-Aug-2003  04:47                    550,780  Procsyst.sql   11-Sep-2003  11:07                     12,305  Qfe469315.sql   22-May-2003  09:27                     19,195  Qfe469571.sql   29-Jan-2004  11:47                  1,090,380  Replmerg.sql   30-Jan-2004  02:59  2000.80.911.0     221,768  Replprov.dll        30-Jan-2004  02:59  2000.80.911.0     307,784  Replrec.dll         29-Jan-2004  09:54  2000.80.911.0     159,813  Replres.rll   05-Sep-2003  10:30                  1,087,150  Replsys.sql   13-Aug-2003  02:58                    986,603  Repltran.sql   30-Jan-2004  02:59  2000.80.911.0     287,304  Rinitcom.dll        30-Jan-2004  02:59  2000.80.911.0      57,916  Semnt.dll           29-Jul-2003  06:43  2000.80.819.0     492,096  Semobj.dll          31-May-2003  04:57  2000.80.818.0     172,032  Semobj.rll   02-Jan-2004  06:12  2000.80.904.0      53,832  Snapshot.exe        09-Dec-2003  06:37                    117,834  Sp3_serv_uni.sql   04-Feb-2004  11:16  2000.80.913.0      28,672  Sqlagent.dll        04-Feb-2004  11:17  2000.80.913.0     311,872  Sqlagent.exe        19-Feb-2004  04:32  2000.80.916.0     168,001  Sqlakw32.dll        30-Jan-2004  02:59  2000.80.911.0   4,215,360  Sqldmo.dll          07-Apr-2003  04:14                     25,172  Sqldumper.exe       29-Jan-2004  09:47  2000.80.911.0      28,672  Sqlevn70.rll   30-Jan-2004  02:59  2000.80.911.0     180,792  Sqlmap70.dll        02-Sep-2003  13:26  2000.80.857.0     188,992  Sqlmmc.dll          02-Sep-2003  09:33  2000.80.857.0     479,232  Sqlmmc.rll   21-Oct-2003  10:38  2000.80.871.0     401,984  Sqlqry.dll          30-Jan-2004  02:59  2000.80.911.0      57,920  Sqlrepss.dll        01-Mar-2004  10:33  2000.80.919.0   7,618,641  Sqlservr.exe        30-Jan-2004  02:59  2000.80.911.0     590,396  Sqlsort.dll         30-Jan-2004  02:59  2000.80.911.0      45,644  Sqlvdi.dll          30-Jan-2004  02:59  2000.80.911.0     106,588  Sqsrvres.dll        30-Jan-2004  02:59  2000.80.911.0      33,340  Ssmslpcn.dll        30-Jan-2004  02:59  2000.80.911.0      82,492  Ssnetlib.dll        30-Jan-2004  02:59  2000.80.911.0      25,148  Ssnmpn70.dll        27-Oct-2003  14:51  2000.80.873.0     123,456  Stardds.dll         30-Jan-2004  02:59  2000.80.911.0     158,240  Svrnetcn.dll        30-Jan-2004  02:59  2000.80.911.0      76,416  Svrnetcn.exe        30-Apr-2003  10:22  2000.80.816.0      45,132  Ums.dll             30-Jan-2004  02:59  2000.80.911.0      98,872  Xpweb70.dll      
Nota debido de dependencias de archivo, la revisión más reciente o característica que contiene estos archivos quizás contenga también archivos adicionales.
Estado
Microsoft ha confirmado que se trata de un problema de los productos de Microsoft enumerados en la sección "La información de este artículo se refiere a".

Este problema se corrigió por primera vez en Pack 4 de Microsoft SQL Server 2000.
Más información
Se produce el comportamiento que se menciona en la sección "Síntomas" cuando establezca una variable de cursor y luego volver a utilizar la misma variable de cursor sin liberar los recursos utilizados por la variable de cursor. Por ejemplo, considere el siguiente procedimiento almacenado:
CREATE PROCEDURE MYPROCBEGIN    DECLARE @CURSOR CURSOR    SET @CURSOR = CURSOR FOR SELECT * FROM AUTHORS     -- FIRST ASSIGNMENT (THIS ASSIGNMENT LEAKS WHEN A SECOND ASSIGNMENT TAKES PLACE WITHOUT DEALLOCATION)        --Other Transact-SQL statements        SET @CURSOR = CURSOR FOR SELECT * FROM AUTHORS    --  SECOND ASSIGNMENT        --Other Transact-SQL statementsEND

Si ejecuta este procedimiento almacenado, puede recibir los mensajes de error de memoria insuficiente. Para resolver el problema, debe modificar el código de procedimiento almacenado como sigue:
CREATE PROCEDURE MYPROCBEGIN    DECLARE @CURSOR CURSOR    SET @CURSOR = CURSOR FOR SELECT * FROM AUTHORS     -- FIRST ASSIGNMENT    --Other Transact-SQL statements    DEALLOCATE @CURSOR --DEALLOCATING THE CURSOR VARIABLE BEFORE A SECOND ASSIGNMENT    SET @CURSOR = CURSOR FOR SELECT * FROM AUTHORS    --  SECOND ASSIGNMENT    --Other Transact-SQL statements    DEALLOCATE @CURSOR --DEALLOCATING THE CURSOR VARIABLE THAT WAS ASSIGNED SECONDEND
Referencias
Para obtener información adicional acerca de las actualizaciones de software, haga clic en el número de artículo siguiente para verlo en Microsoft Knowledge Base:
824684Descripción de la terminología estándar utilizada para describir las actualizaciones de software de Microsoft
Para obtener información adicional acerca de la memoria asuntos relacionados, haga clic en los números de artículo siguientes para verlos en Microsoft Knowledge Base:
810052REVISIÓN: Se produce una pérdida de memoria cuando se abren cursores durante una conexión
818095REVISIÓN: Los planes de cursor no se quitan la caché cuando se agota la memoria virtual
820773REVISIÓN: El controlador JDBC pérdidas cursores de servidor
271624INF: Utilizar DBCC MEMORYSTATUS supervisar el uso de memoria de SQL Server

Propiedades

Id. de artículo: 837957 - Última revisión: 12/08/2015 06:32:24 - Revisión: 3.3

Microsoft SQL Server 2000 Developer Edition, Microsoft SQL Server 2000 Standard Edition, Microsoft SQL Server 2000 Enterprise Edition, Microsoft SQL Server 2000 Personal Edition, Microsoft SQL Server 2000 Workgroup Edition, Microsoft SQL Server 2000 Desktop Engine (Windows), Microsoft SQL Server 2000 Enterprise Edition 64-bit

  • kbnosurvey kbarchive kbmt kbhotfixserver kbqfe kbqfe kbtsql kbsqlprog kbquery kberrmsg kbmemory kbsqlserv2000presp4fix kbfix kbbug KB837957 KbMtes
Comentarios
ERROR: at System.Diagnostics.Process.Kill() at Microsoft.Support.SEOInfrastructureService.PhantomJS.PhantomJSRunner.WaitForExit(Process process, Int32 waitTime, StringBuilder dataBuilder, Boolean isTotalProcessTimeout)