FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
Obtener ClaveMaestra del registro insertado.
Tengo dos tablas en una DB de Access 97.
Código:
Campos Tabla1:Id: Autonumérico y Clave Maestra. Numero: Numérico. Nombre: Texto.Campos Tabla2:Id: Autonumérico y Clave Maestra. Numero: Numérico Con ADO estoy intentando insertar un registro en Tabla1 y simultánemente insertar en Tabla2 una serie de registros vinculados al registro que inserto en Tabla1.
El problema lo tengo para obtener el valor que se le ha asignado al campo ID al insertar el registro en la Tabla1, teniendo en cuenta que simultáneeamente otras apliaciones pueden realizar lo mismo. ¿Cómo podría obtenerlo? Gracias de antemano. |
#2
|
|||
|
|||
mmmm, no he trabajado con ADO, pero creo que hay algún error en ese código que has puesto
si Id es autonumérico.... ¿por qué le asignas un valor? si Id es autonumérico.... después del Post puedes consultar su valor, ¿no? Podría quedar algo así
Repito, no he trabajado con ADO, así que no se como funciona exactamente el tema de refrescos y tal en este motor |
#3
|
|||
|
|||
Mi amigo..
Mi amigo cadetill
si Id es autonumérico.... ¿por qué le asignas un valor? ¡¡Nunca le da un valor al Autonumerico ahora si viste mal Y bueno la cosa es que este tema se ha tratado muchas veces Funciona bien si no lo van a usar varias instancias con un solo Last
Ahora si lo van a usar varios no se si TADOTable tenga la opcion de exclusive
__________________
saludos desde Puebla Mexico.. asanxt@hotmail.com "como siempre a sus ordenes y siempre con buena cara" 'lolita me excitas, perversa piel de melocotón' |
#4
|
|||
|
|||
Cita:
Pero bueno, sigo pensando que, justo despues del Post (que no hace falta hacer un Last ya que te encuentras en el registro en cuestión) tienes el valor del ID accediendo al campo de la tabla tal y como muestras (o yo quería mostrar). El cursor no se mueve del registro mientras no realices otro Append (Insert), Next, Last, Prior o First PD: si es que ya es hora de irse a la cama!!!! |
#5
|
||||
|
||||
Bueno... el cursor no se mueve de registro en el dataset, pero me parece (salvo que ADO trabaje sensiblemente diferente al BDE en esta parte) que el registro no estará "actualizado". Es decir, no mostrará el valor asignado al campo en la base de datos.
En el caso del BDE, lo que ocurre es que éste motor se basa en la llave primaria para hacer un refresh del registro inmediatamente después de insertarlo, de manera que cualquier asignación hecha del lado del servidor, via triggers por ejemplo, se refleje en el cliente. El talón de aquiles de este mecanismo, por supuesto, son las asignaciones del lado del servidor a algún campo que forma parte de la clave primaria. Esto es simplemente imposible con el BDE, y dado que se basa en el "minimo común" de todas las BD's, supongo que no idearon la forma de realizarlo. Conozco algunos motores de base de datos que implementan un mecanismo para prevenir esto, pero varia de motor en motor... creo que el único que no tiene un mecanismo para identificar de nuevo al registro es interbase/firebird, aunque habría que consultar a los expertos... ADO funciona de otra forma? Hasta luego.
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate |
#6
|
|||
|
|||
Cita:
|
#7
|
|||
|
|||
El código que he puesto es un ejemplo, sólo eso.
En cuanto a recuperar el valor del campo Tabla1-Id tras el Post, lo intenté en: la línea de código tras el post, en el evento afterpost de la tabla y en el evento SetText y Validate del campo con el mismo resultado 0. Otra forma que se me ha ocurrido es utilizar una sentencia SQL, aunque no sé si es factible crear una sentencia que insert un registro y devuelva la fila insertada. Si teneis cualquier sugerencia os la agradecería. Saludos Juan P. |
#8
|
||||
|
||||
A mi saber no es posible recuperar la fila seleccionada. Access no tiene algun mecanismo tipo generadores que te permita asignar el código desde el cliente??
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate |
#9
|
||||
|
||||
Vamos a ver, que no estoy entendiendo lo qe dice jachguate:
Si tengo una tabla en paradox con un campo autonumérico e inserto un registro, inmediatamente depués del post puedo obtener el valor que se asignó al campo. |
#10
|
||||
|
||||
Bueno... ya sabes que Paradox es un caso especial del BDE, al igual que los DBF's, y no se si algun otro. Lo que yo digo es aplicable para bases de datos SQL (al menos desde el punto de vista del propio BDE, pues Access sigue cayendo en esta categoria, segun mi criterio).
Hasta luego.
__________________
Juan Antonio Castillo Hernández (jachguate) Guía de Estilo | Etiqueta CODE | Búsca antes de preguntar | blog de jachguate |
#11
|
||||
|
||||
Pues el problema es raro. Acabo de hacer la prueba con ADO con Access y es como suponía cadetill, el valor del autonumérico lo obtengo inmediatamente después del Post. De hecho esto lo había ya señalado sanxpue desde un principio, si bien él agrega el uso de Last.
|
#12
|
|||
|
|||
Bien por lo que dice Roman algo debo estar haciendo mal.
Acabo de hacer nuevamente la prueba con el código siguiente:
Y el valor de de k es siempre cero. La cadena de conexión es: Código:
Provider=Microsoft.Jet.OLEDB.4.0;User ID=Admin; Data Source=E:\Documents and Settings\casa\Mis Documentos\Trabajo\Estudio_ADO\bd2.mdb; Mode=Share Deny None;Extended Properties=""; Jet OLEDB:System database="";Jet OLEDB:Registry Path=""; Jet OLEDB:Database Password="";Jet OLEDB:Engine Type=4; Jet OLEDB:Database Locking Mode=0;Jet OLEDB:Global Partial Bulk Ops=2; Jet OLEDB:Global Bulk Transactions=1; Jet OLEDB:New Database Password=""; Jet OLEDB:Create System Database=False; Jet OLEDB:Encrypt Database=False; Jet OLEDB:Don't Copy Locale on Compact=False; Jet OLEDB:Compact Without Replica Repair=False; Jet OLEDB:SFP=False ¿dónde está el error? |
|
|
|