Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Conexión con bases de datos (https://www.clubdelphi.com/foros/forumdisplay.php?f=2)
-   -   BB.DD. Access (https://www.clubdelphi.com/foros/showthread.php?t=93643)

Angel.Matilla 18-12-2018 19:08:28

BB.DD. Access
 
Necesito leer una base de datos en Access. El problema que tengo es que la versión de Access que tengo es la 2007 y cuando trato de abrir dicho fichero me dice que no reconoce el formato de la misma. ¿Alguien puede echarme una mano? El fichero, una vez comprimido en formaton RAR, ocupa 901 Kb.

Angel.Matilla 18-12-2018 19:30:49

Tengo la sensación de que la base de datos está protegida con alguna herramienta externa porque tengo otra copia anterior y desactualziada que sí puedo leer correctamente.

Neftali [Germán.Estévez] 18-12-2018 19:58:18

La otra opción es que esté realizada con un Access más nuevo (Office 2016, por ejemplo) y que la versión antigua no pueda abrirlo.
No tienes nadie con una versión más nueva que pueda hacer la prueba.

Si es así, una vez abierto con la versión nueva, siempre puedes convertirla a la que tienes tú.

Angel.Matilla 18-12-2018 21:15:55

Lo de la versión más moderna no porque la aplicación que la usa ya es antigua y el programador que la hizo ya falleció por desgracia. Mañana haré una prueba y será pedirle al usuario que me haga una copia de la misma mientras tiene lanzada la aplicación, a ver si nos deja.

Angel.Matilla 19-12-2018 10:28:00

No se ha podido. Sé que era un intento difícil de conseguir pero había que probarlo. Y lo malo es que no sé como han hecho para proteger el fichero.

Neftali [Germán.Estévez] 19-12-2018 12:28:35

Las Base de Datos de Access se pueden proteger con contraseña y utilizando seguriddad de Access, pero en ambos casos a la hora de abrirlos el error/aviso suele ser claro.
Es raro el error que obtienes...

Angel.Matilla 19-12-2018 12:45:32

El error que da es este:

Si pulso en ayuda me da el código de error 3343. Como le he comentado a Casimiro Notevi me suena a una herramienta similar que usábamos en programción Clipper que modificaba un bit de los ficheros lo que hacía que dBase III no pudiera abrirlos.

Casimiro Notevi 19-12-2018 14:30:47

Àngel, creo que no está protegida de ninguna forma, solamente está corrupta.

ElDioni 19-12-2018 14:33:03

Es posible que la conexión a la base de dato se hiciera con el proveedor "Microsoft Jet 4.0 OLE DB Provider", al ser una tabla más actualizada cre que deberías probar con el proveedor de datos "Microsoft Office 12.0 Access Database Engine OLE DB Provider".


Saludos.

ElDioni 19-12-2018 14:34:10

Cita:

Empezado por Casimiro Notevi (Mensaje 530046)
Àngel, creo que no está protegida de ninguna forma, solamente está corrupta.


Si la tabla está corrupta, al abrirla con access, el mismo programa te avisa y te indica que tiene que repararla y compactarla.


De todas formas no está de más hacer esto mismo para ver si se soluciona el tema.



Saludos.

Casimiro Notevi 19-12-2018 14:36:10

La cabecera parece estar bien e indica que es "Standar jet db":
Seguramente la parte dañada esté en alguna zona de los datos, me temo que tendrás que buscar alguna herramienta de reparación.



Casimiro Notevi 19-12-2018 14:37:18

Cita:

Empezado por ElDioni (Mensaje 530048)
Si la tabla está corrupta, al abrirla con access, el mismo programa te avisa y te indica que tiene que repararla y compactarla.
De todas formas no está de más hacer esto mismo para ver si se soluciona el tema.
Saludos.

También puede ser.

ElDioni 19-12-2018 14:42:21

Cita:

Empezado por Casimiro Notevi (Mensaje 530049)
La cabecera parece estar bien e indica que es "Standar jet db"...


No vale, tú tienes más infomación que yo.


Si access te deja abrirla y dándole a "reparar y compactar" no te soluciona el problema y no tienes ninguna otra herramienta para arreglar la BBDD, crea un archivo nuevo de access y ve copiando y pegando las tablas de la base de datos vieja a la nueva.


Saludos.

Angel.Matilla 19-12-2018 18:06:56

Cita:

Empezado por Casimiro Notevi (Mensaje 530046)
Àngel, creo que no está protegida de ninguna forma, solamente está corrupta.

Tal vez, pero creo que no por una sencilla razón: cuando el usuario abre la aplicación hecha con Access puede trabajar sin ningún problema.

jafera 19-12-2018 18:15:51

Buenas a todos.


Angel, yo tambien tengo que leer semanalmente una base de acces y no tengo acces instalado en mi ordenador ya que no lo uso, y mira que llegue a programar incluso una gestion completita con una version profesional que hubo en su momento.

Para este fin hay una herramienta que se llama MDBPlus y me abre siempre los acces sin el mínimo problema.

http://www.alexnolan.net/software/mdb_viewer_plus.htm

Saludos


Josep

Angel.Matilla 19-12-2018 18:58:37

Mcuhas gracias. Ahora mismo lo descargo y lo pruebo.

Angel.Matilla 19-12-2018 19:00:43

Cita:

Empezado por jafera (Mensaje 530053)
Para este fin hay una herramienta que se llama MDBPlus y me abre siempre los acces sin el mínimo problema.

¡Mi gozo en un pozo! ME da el mismo error que cuando trato de abrirlo con Access

Angel.Matilla 19-12-2018 19:12:44

Cita:

Empezado por ElDioni (Mensaje 530048)
Si la tabla está corrupta, al abrirla con access, el mismo programa te avisa y te indica que tiene que repararla y compactarla.

Cuando intento abrir la bb.dd., tanto con Access como con la aplicación Builder, el mensaje que da es el que puse antes.
Cita:

Empezado por Casimiro Notevi (Mensaje 530049)
La cabecera parece estar bien e indica que es "Standar jet db":

Eso me pareció al compararlas con las de otra bb.dd. que sí puedo abrir. Y por eso te comentaba en mi correo que se parecía mucho a esa herramienta que tuve para tabls dBase III; ¡cuánto más fácil era programar con esas elementales herramientas!
Cita:

Empezado por ElDioni (Mensaje 530051)
No vale, tú tienes más infomación que yo.

:D
Cita:

Empezado por ElDioni (Mensaje 530051)
Si access te deja abrirla y dándole a "reparar y compactar" no te soluciona el problema y no tienes ninguna otra herramienta para arreglar la BBDD, crea un archivo nuevo de access y ve copiando y pegando las tablas de la base de datos vieja a la nueva.

Sácame de una duda: Si no puedo abrir la bb.dd. ¿cómo hago para copiar las tables desde esa que no puedo abrir a una nueva? Me tiene intrigado la propuesta :confused:

Casimiro Notevi 20-12-2018 11:03:36

Entonces ¿puedes abrirla con el programa original que la maneja?
Si es así, ¿no tiene ninguna opción para exportar datos?

Si no tiene exportación, puedes enviar un listado a una impresora virtual y ya lo tienes en un fichero de texto.

Angel.Matilla 20-12-2018 11:59:02

Cita:

Empezado por Casimiro Notevi (Mensaje 530078)
Entonces ¿puedes abrirla con el programa original que la maneja?
Si es así, ¿no tiene ninguna opción para exportar datos?

Si no tiene exportación, puedes enviar un listado a una impresora virtual y ya lo tienes en un fichero de texto.

Con la aplicación original se abre y funcion sin ningún problema. Me parece que no tiene la opción de exportar datos y como es uan aplicación cerrada los listados no me darían la información completa de todas las bases de datos. Creo que el usuario no tiene instalado MSAccess, que es lo que nos faltaría probar pero es más que probable que aunque lo tuviera instalado no pudieramos acceder desde él a la base de datos; lo digo porque ayer con la aplicación lanzada intentamos hacer una copia del fichero y no pudimos porque estaba "bloqueado por otro usuario".

Y he localizado a uno de los que desarrolló la aplicación (no el programador que es el que falleció), pero esta persona dispone de la herramienta para "abrir" la base de datos. Lo lamentable es que no me la da y me va a volver a hacer falta dentro de poco para otro usuario distinto, pero cuando me remita la base de datos abierta podríamos comparar las cabeceras de ambos ficheros para ver que varía de uno a otro.


La franja horaria es GMT +2. Ahora son las 11:16:33.

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