Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > MS SQL Server
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 16-12-2005
Oxa78 Oxa78 is offline
Miembro
 
Registrado: may 2003
Ubicación: Lima - Peru
Posts: 110
Poder: 21
Oxa78 Va por buen camino
Primary Key - SQL Server

Saludos :

Parece q estyo sin rumbo, tengo un sistema con Delphi 7 + MS SQl Server 2000 y bueno tengo una tabla de mivimientos :

* Tabla de Movimientos tiene un Número de Registro Unico (ID), este número unico lo encuentro con una consulta SQL buscando el máximo luego le sumo 1 y tengo el nuevo id, incluyo esta consulta en una trnasacción para asegurar q el id no se repita.

Esta tabla tiene un índice q es el ID pero que no es Primary Key.

PREGUNTA : ¿ Que tan importante es señalar el campo como Primary Key ?

Si solo creo un índice, ¿ Esta bien ?

¿ Tendre problemas en las grabaciones masivas con "ApplyUpdates" sino no tengo Primary Key en la tabla ?

¿ Que me recomiendan ?

Muchas Gracias por adelantado....
__________________
Joseph Buttgembach Verde
Lima - Perú
Responder Con Cita
  #2  
Antiguo 16-12-2005
Migpal Migpal is offline
Miembro
 
Registrado: jul 2005
Ubicación: Colombia
Posts: 91
Poder: 19
Migpal Va por buen camino
Si pagas por usar MSSQL y no utilizas primary key con clusters, es como si compraras un carro automatico y le buscaras los cambios para operarlo.
Responder Con Cita
  #3  
Antiguo 16-12-2005
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.275
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
Cita:
Empezado por Oxa78
Tabla de Movimientos tiene un Número de Registro Unico (ID), este número unico lo encuentro con una consulta SQL buscando el máximo luego le sumo 1 y tengo el nuevo id, incluyo esta consulta en una trnasacción para asegurar q el id no se repita...

¿ Que me recomiendan ?
* Utiliza Primary Keys
* Utiliza índices (clustered en tu caso del ID)
* En lugar de contador + 1, utiliza un campo autoincremental. Evitarás problemas de que dos generen enl mismo número (que en la forma en que lo estás haciendo es posible aunque tengas una transaccion -con el nivel de aislamiento por defecto que trae SQL Server-; Ya que la transaccion te evita bloqueos, pero no duplicados).
Dos transacciones que se ejecuten: la A lee, luego la B lee (hasta aquí con el nivel de aislamiento de SQL Server es posible), luego la A suma 1 y hace commit, luego la B suma 1 y hace commit ==> ERROR.

Te adjunto un trozo de la documentacion de SQL Server:
-----------------------------------------------------------------------
READ COMMITTED

Especifica que se mantengan los bloqueos compartidos mientras se leen datos para evitar lecturas no actualizadas, pero se pueden modificar los datos antes del final de la transacción, lo que provoca lecturas no repetibles o datos fantasma. Esta opción es la predeterminada en SQL Server.

-----------------------------------------------------------------------
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.

Última edición por Neftali [Germán.Estévez] fecha: 16-12-2005 a las 17:26:22.
Responder Con Cita
  #4  
Antiguo 09-01-2006
Avatar de Chente(rMan)
Chente(rMan) Chente(rMan) is offline
Miembro
 
Registrado: ago 2005
Posts: 89
Poder: 19
Chente(rMan) Va por buen camino
Que tal Oxa78, lo que te recomiendo es lo mismo que Neftalí, utiliza campos autoincrementables, tu solo insertar y SQL se encarga de lo demas, por ejemplo tu tabla movimientos tiene 3 campos Id, fecha, cantidad, imagina que insertar los datos con fecha de hoy

Código SQL [-]
insert movimientos (fecha, cantidad)
values (getdate, 9)
select SCOPE_IDENTITY()

lo que hara el SCOPE_IDENTITY() es devolverte el número autoincrementable que le asigno SQL.



Saludos.

Vicente López.
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro


La franja horaria es GMT +2. Ahora son las 15:08:28.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi