Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Varios
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Grupo de Teaming del ClubDelphi

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 02-08-2024
darkamerico darkamerico is offline
Miembro
 
Registrado: dic 2010
Posts: 267
Poder: 14
darkamerico Va por buen camino
Red face Como saber si se insertó un registro en una tabla

Saludos amigos,
El caso es el siguiente: Existe una aplicación (No hecha en delphi) que maneja su BD en SQL Server, la tarea que me han encomendado es saber si en una tabla especifica se realizó un Insert. Obviamente tengo acceso a dicha BD, desde mi aplicacion "Monitor" y mantener un contador de las filas insertadas alli.

Atte,
Americo
Responder Con Cita
  #2  
Antiguo 02-08-2024
Avatar de delphi.com.ar
delphi.com.ar delphi.com.ar is offline
Federico Firenze
 
Registrado: may 2003
Ubicación: Buenos Aires, Argentina *
Posts: 5.953
Poder: 27
delphi.com.ar Va por buen camino
Puedes saber que se ingresaron registros en una tabla por muchos medios, pero no puedes saber si el origen del dato es la aplicación.

Sin conocer el modelo de datos, puedes hacer algo de todo esto:
  • Comparar el valor de la secuecia autoincremental del la tabla (sys.identity_columns)
  • Agregar un trigger para generar datos en una tabla tuya que registre fecha y hora de la inserción de los datos.
  • Contar registros (fallaría si se borran datos)
  • Consultar el MAX de algún campo secuencia (si no está indexado es inóptimo)

Saludos.
__________________
delphi.com.ar

Dedique el tiempo suficiente para formular su pregunta si pretende que alguien dedique su tiempo en contestarla.
Responder Con Cita
  #3  
Antiguo 02-08-2024
darkamerico darkamerico is offline
Miembro
 
Registrado: dic 2010
Posts: 267
Poder: 14
darkamerico Va por buen camino
Red face

Cita:
Empezado por delphi.com.ar Ver Mensaje
Puedes saber que se ingresaron registros en una tabla por muchos medios, pero no puedes saber si el origen del dato es la aplicación.

Sin conocer el modelo de datos, puedes hacer algo de todo esto:
  • Comparar el valor de la secuecia autoincremental del la tabla (sys.identity_columns)
  • Agregar un trigger para generar datos en una tabla tuya que registre fecha y hora de la inserción de los datos.
  • Contar registros (fallaría si se borran datos)
  • Consultar el MAX de algún campo secuencia (si no está indexado es inóptimo)

Saludos.
Antes de nada agradecer la respuesta.
Estoy usando los componentes UniDAC, me preguntaba si quizás existe algún evento del dataset (TUniTable o TUniQuery) desde mi aplicación que apunta a esa tabla que se dispare de forma asíncrona cada vez que dicha tabla registra un nuevo registro.

Atte

Última edición por darkamerico fecha: 02-08-2024 a las 17:32:20.
Responder Con Cita
  #4  
Antiguo 02-08-2024
Avatar de delphi.com.ar
delphi.com.ar delphi.com.ar is offline
Federico Firenze
 
Registrado: may 2003
Ubicación: Buenos Aires, Argentina *
Posts: 5.953
Poder: 27
delphi.com.ar Va por buen camino
Si se inserta desde otra aplicación, tu aplicación no va a recibir un evento de la base de datos.
Yo exploraría mediante un uso de un trigger y xp_cmdshell, para que al momento de crear un registro se ejecute una aplicación que notifique a la tuya, mediante un socket o similar. Desconozco SqlServer, pero algunos motores te permiten escribir tus propias librerías para cálculo donde puedes introducir tu mecanismo de notificación.

Saludos.
__________________
delphi.com.ar

Dedique el tiempo suficiente para formular su pregunta si pretende que alguien dedique su tiempo en contestarla.
Responder Con Cita
  #5  
Antiguo 03-08-2024
darkamerico darkamerico is offline
Miembro
 
Registrado: dic 2010
Posts: 267
Poder: 14
darkamerico Va por buen camino
Red face

Cita:
Empezado por delphi.com.ar Ver Mensaje
Si se inserta desde otra aplicación, tu aplicación no va a recibir un evento de la base de datos.
Yo exploraría mediante un uso de un trigger y xp_cmdshell, para que al momento de crear un registro se ejecute una aplicación que notifique a la tuya, mediante un socket o similar. Desconozco SqlServer, pero algunos motores te permiten escribir tus propias librerías para cálculo donde puedes introducir tu mecanismo de notificación.

Saludos.
ok amigo, veré que opciones puedo explorar, gracias
Responder Con Cita
  #6  
Antiguo 05-08-2024
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.432
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 delphi.com.ar Ver Mensaje
  • Comparar el valor de la secuecia autoincremental del la tabla (sys.identity_columns)
  • Agregar un trigger para generar datos en una tabla tuya que registre fecha y hora de la inserción de los datos.
  • Contar registros (fallaría si se borran datos)
  • Consultar el MAX de algún campo secuencia (si no está indexado es inóptimo)

A lo comentado por [delphi.com.ar] yo añadiría las "Query Notifications" (link); Ya que estás con FireDAC (TFDEventAlerter (link)) y SQLServer, con esta configuración puedes usarlas (SQLServer las tiene y FireDAC las implementa).

Aquí tienes la lista de Base de Datos que las soportan y que puedes acceder a ellas utilizando FireDAC.


Cita:
Empezado por delphi.com.ar Ver Mensaje
Si se inserta desde otra aplicación, tu aplicación no va a recibir un evento de la base de datos.

En el caso de "Query Notifications" son contra la Base de Datos, por lo tanto es independiente de la aplicación con la que se hayan insertado/Modificado/Borrado los registros de la tabla. Tu aplicación recibe las notificaciones que le hayas programado,
Tienes la explicación completa de cómo hacerlo, con todo lo necesario y un proyecto con código fuente en esta entrada de mi blog:
https://neftali.clubdelphi.com/event...notifications/

IMPORTANTE: Lo explica en el artículo, que tienes que activar el servicio ENABLE_BROKER para la Base de Datos (si no lo tiene activo). Ahí tienes cómo consultarlo y cómo activarlo si es necesario.
__________________
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.
Responder Con Cita
  #7  
Antiguo 07-08-2024
darkamerico darkamerico is offline
Miembro
 
Registrado: dic 2010
Posts: 267
Poder: 14
darkamerico Va por buen camino
Red face

Cita:
Empezado por Neftali [Germán.Estévez] Ver Mensaje
A lo comentado por [delphi.com.ar] yo añadiría las "Query Notifications" (link); Ya que estás con FireDAC (TFDEventAlerter (link)) y SQLServer, con esta configuración puedes usarlas (SQLServer las tiene y FireDAC las implementa).

Aquí tienes la lista de Base de Datos que las soportan y que puedes acceder a ellas utilizando FireDAC.





En el caso de "Query Notifications" son contra la Base de Datos, por lo tanto es independiente de la aplicación con la que se hayan insertado/Modificado/Borrado los registros de la tabla. Tu aplicación recibe las notificaciones que le hayas programado,
Tienes la explicación completa de cómo hacerlo, con todo lo necesario y un proyecto con código fuente en esta entrada de mi blog:
https://neftali.clubdelphi.com/event...notifications/

IMPORTANTE: Lo explica en el artículo, que tienes que activar el servicio ENABLE_BROKER para la Base de Datos (si no lo tiene activo). Ahí tienes cómo consultarlo y cómo activarlo si es necesario.
Gracias Nelfali, un fuerte abrazo.
Estoy en modo investigación.


Atte
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

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Saber si un registro de una tabla está siendo utilizado en otras. Gregorio Cíber SQL 7 02-10-2019 22:32:53
Como puedo saber el ultimo numero de un registro amell2020 Varios 6 23-11-2011 20:38:41
como inserto un SubMenu? lpaburto Varios 1 14-10-2005 16:49:07
¿Cómo inserto los campos con formato TGraphic y TMemo en una tabla? nuri SQL 0 22-07-2005 13:35:59
¿Cómo inserto, mediante un query, un registro en paradox con un campo autoincrement? molarte Tablas planas 2 18-11-2004 17:27:30


La franja horaria es GMT +2. Ahora son las 17:29:53.


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