Club Delphi  
    Paypal   FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > Conexión con bases de datos
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Conexión con bases de datos

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 25-02-2016
jars jars is offline
Miembro
 
Registrado: mar 2004
Posts: 283
Poder: 23
jars Va por buen camino
[elkurgan] los campos blob se actualizan siempre. Gracias
Responder Con Cita
  #2  
Antiguo 25-02-2016
Avatar de Casimiro Noteví
Casimiro Noteví Casimiro Noteví is offline
Merodeador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.670
Poder: 10
Casimiro Noteví Tiene un aura espectacularCasimiro Noteví Tiene un aura espectacular
¿Qué almacenas en esos campos blob?
Responder Con Cita
  #3  
Antiguo 25-02-2016
jars jars is offline
Miembro
 
Registrado: mar 2004
Posts: 283
Poder: 23
jars Va por buen camino
Lo que almaceno en el campo blob es un registro bastante grande con datos de todo tipo.
Responder Con Cita
  #4  
Antiguo 25-02-2016
Avatar de Casimiro Noteví
Casimiro Noteví Casimiro Noteví is offline
Merodeador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.670
Poder: 10
Casimiro Noteví Tiene un aura espectacularCasimiro Noteví Tiene un aura espectacular
Cita:
Empezado por jars Ver Mensaje
Lo que almaceno en el campo blob es un registro bastante grande con datos de todo tipo.
Preguntabas si se pueden comprimir esos datos, por eso mi duda. Entonces, evidentemente, si es un zip, un jpg, etc. no podrás comprimirlo. Si es texto, sí.

Me temo que el método que estás usando no es el más indicado para trabajar con campos blob.
Responder Con Cita
  #5  
Antiguo 25-02-2016
jars jars is offline
Miembro
 
Registrado: mar 2004
Posts: 283
Poder: 23
jars Va por buen camino
Lo que quiero comprimir no es ni zip ni jpg es un registro como este (una parte):

Código Delphi [-]
  TPos = record
    PosNum: Word;                
    AgentId: string[10];                
    AgentName: string[30];           
    State: Byte;                        
    PosFlags: set of TPosFlag;        
    SkillSet: TSkillSet;                   
    SkillsDistribution: TSkillsDist;   
    CurrentCallSkill: Byte;            
    CurrentStateTime: Word;        
    PosIdleTime: Word;                
    PosLockedTime: Word;           
  .......
sigue bastante mas

Lo que quería probar ahora era comprimirlo antes de meterlo en el campo blob y no se como hacerlo.

Por otro lado si este no es el método indicado acepto cualquier sugerencia para cambiarlo.
Responder Con Cita
  #6  
Antiguo 25-02-2016
Avatar de Casimiro Noteví
Casimiro Noteví Casimiro Noteví is offline
Merodeador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.670
Poder: 10
Casimiro Noteví Tiene un aura espectacularCasimiro Noteví Tiene un aura espectacular
Sería necesario conocer bastante más detalles de tu sistema para poder recomendarte algo.

El código que has puesto no nos dice nada sobre lo que guardas el blob. Si son esos "record", entonces es texto. La verdad es que no se entiende bien qué estás haciendo. Sería necesaria más información.
Responder Con Cita
  #7  
Antiguo 25-02-2016
jars jars is offline
Miembro
 
Registrado: mar 2004
Posts: 283
Poder: 23
jars Va por buen camino
Voy a tratar de hacerme entender.
El programa recolecta información desde otro módulo a un ritmo de 2 veces por segundo, procesa esa información, la vuelca en el registro en cuestion y envía ese registro a distintos puestos via tcp. Esto viene funcionando hace años y bien.
La cosa es que ahora se necesita cada tanto tiempo (pej. 1 minuto) bajar ese registro a la BBDD para que en caso de corte de luz o cualquier otro problema, no se pierda la información acumulada hasta el momento. Este programa lleva una estadística diaria y no se puede perder es por eso que se necesita resguardarla en BBDD para que a lo sumo se pierda el último minuto y no todo.
El registro tiene un tamaño de 230K (si, es grande), logre comprimirlo y lo deja en aproximadamente 10.5 k.
Mi última prueba fue de no manejar una tabla en memoria, directamente tomar el registro, comprimirlo y hacer un comando SQL Insert pero me encuentro que al llegar al registro 359 siempre se cuelga con un Acces violation en una direccion 005a2000 no hay nada ahi. Este es el código que estoy probando:

Código Delphi [-]

type
  TPos = packed record
    PosNumber: Word;
    AgentId: string[10];
    AgentName: string[30];
    State: Byte;               
    ChatState: TChatState;
    PosFlags: set of TPosFlag;
    SkillSet: TSkillSet;           
    SkillsDistribution: TSkillsDist;
    CurrentCallSkill: Byte;         
    IMRSessions: string[250];    
    CurrentStateTime: Word;     
    PosIdleTime: Word;             
    PosLockedTime: Word;        
    PosLockedAnswTime: Word; 
    ......
end;

// tamaño total 230.000

procedure TRecord2BlobForm.btnUpdClick(Sender: TObject);
var
  i: Integer;
  s, zip: TMemoryStream;
begin
  Q.SQL.Add('INSERT INTO SESSION_DATA VALUES(:ID, ATA)');
  Q.Prepare;

  Sched.StartTransaction;
  for i := 0 to 999 do
    with Pos[i] do
    begin
      s   := TMemoryStream.Create;
      zip := TMemoryStream.Create;

      try
        s.Write(Pos[i], SizeOf(TPos));
        s.Position := 0;
        ZCompressStream(s, zip, zcMax);
        Q.ParamByName('ID').Value := i;
        Q.ParamByName('DATA').LoadFromStream(zip, ftBlob) ;
        Q.ExecSQL;
      finally
        FreeAndNil(s);
        FreeAndNil(zip);
      end;
      if i mod 50 = 0 then
      begin
        Sched.Commit;
        Sched.StartTransaction;
      end;
    end;
  if Sched.InTransaction then Sched.Commit;
end;

Espero me haberme hecho entender.
Gracias.
Responder Con Cita
  #8  
Antiguo 26-02-2016
Avatar de mamcx
mamcx mamcx is online now
Moderador
 
Registrado: sep 2004
Ubicación: Medellín - Colombia
Posts: 3.939
Poder: 27
mamcx Tiene un aura espectacularmamcx Tiene un aura espectacularmamcx Tiene un aura espectacular
Cita:
Empezado por jars Ver Mensaje
Lo que quiero comprimir no es ni zip ni jpg es un registro como este (una parte):
Lo que te dice casimiro es muy cierto. Ahora, el porque no te esta funcionando el uso normal es porque en el esquema relacional basico es facil comparar los valores en cada celda (y es "economico" hacer comparacion entre antes y despues para valores estandar), pero el uso de BLOBs hace que un minimo cambio haga que toda esa fila tenga que actualizarse.

Esa es una de las razones por la que almacenar archivos se recomienda hacerlo por fuera de la tabla.

El tema de fondo, es que estas empaquetando un "micro base de datos" dentro de una celda de una fila de una tabla. Si lo comprimes? Si claro, queda mas pequeño y eso es buena para transferencias PERO, es el mismo lio: NO IMPORTA si son archivos o campos o texto: Estas metiendo una BD dentro de un campo.

Entiende que al final: Los campos son bytes, y sean archivos u otra cosa tienen una estructura. Al usar un blob estas "rompiendo" la estructura "normal" de una tabla y le estas metiendo algo "desconocido" como un valor. De ahi, que la BD no tiene ni idea de que hacer hasta que no desempaquetas y descifras ese valor.

Me sigues? Compresion o tipo de datos no es lo fundamental - de hecho, es tangencial-: Es que pasaste de un mundo a otro y ese otro mundo esta rompiendo con las reglas predecibles.

------

Que hacer? Ayuda que nos des mas info. Pero por la pinta de esto, hay 2 caminos basicos:

1- Convierte ese BLOB en tablas, relaciones y ahora si podra operar todo normal.
2- Separar logica y muy seguramente, fisicamente los datos BLOB de los normales, y aplicas logica extra a ese blob para saber si actualizas o no. Osea, tratas como si ese blob fuera un archivo, y asi como un motor SQL no sabe procesar JPGs, asi en este caso.

De esa manera, cambios en los datos basicos no interfieren con el blob y viceversa.

Y para actualizar el blob de forma eficiente? Aparte de usar tablas relacionales (que parece muy viable) puede hacer un DIFF para chequear cambios y solo extraer lo necesario y ejecutar un PATCH en el servidor junto con un HASH para certificar que la actualizacion fuer correcta y exitosa. O si el cambio en el blob es muy frequente, usar un LOG manual de transacciones donde describes los pasos aplicados en el cliente, y le haces un MERGE en el servidor.

Como con archivos.
__________________
El malabarista.
Responder Con Cita
Respuesta


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

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
Mover datos de tabla en memoria a tabla mysql webmasterplc SQL 0 07-04-2014 05:12:33
Problema con Stored Procedure para actualizar tabla con datos de otra tabla. Adrian Murua MySQL 4 04-02-2012 02:54:49
Actualizar tabla con datos de otra tabla mediante UPDATE Rockin Firebird e Interbase 18 28-11-2007 19:15:42
Como actualizar una tabla cada cierto tiempo leodenis784 Conexión con bases de datos 4 01-08-2006 13:58:38
Una Transacción por cada Tabla???? AGAG4 Conexión con bases de datos 5 22-12-2004 03:24:44


La franja horaria es GMT +2. Ahora son las 22:01:20.


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