FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
||||
|
||||
Actualizar un Registro Por SQL con varios parametros
Saludos, y gracias por su atención.
Tengo una tabla "Cuotas" (Uso access), a la cual le quiero hacer un UPDATE por sql con un ADOQuery, Quiero actualizar tres campos, 1- 'Fecha_Pago' que inicialmente esta vacío, "con la fecha actual" 2- 'Estado' con "realizado" 3- 'Mora' Con un valor numérico que esta en un edit, llamemoslo edit1 para encontrar el registro tomara en cuenta tres cosas, el campo 'NumPrestamo' que agrupa todos los registros relacionados a un préstamo, luego el campo 'Estado' que contiene el texto "Pendiente o Realizado" lo que quiere que solo tome en cuenta los registros que tengan "Pendiente" y por ultimo, 'Numero' que tiene el numero de la cuota, la cuestión es que quiero que seleccione el registro que tenga en este campo "Numero" el valor mas bajo, la idea es ir cambiando el registro en el orden ascendente cuando realizo cada UPDATE. Por toda la explicación que he dado ya saben de que trata el programa, y se que la gran mayoria ha hecho esto o algo parecido. soy otro novato buscando ayuda Espero sus respuestas, Gracias. |
#2
|
||||
|
||||
Tú mismo has descrito perfectamente la sentencia sql que hay que escribir, ya solamente te falta mirar cualquier tutorial sql
Y de esa manera dejarás de ser novato, porque si te la escribimos, entonces tú la copiarás y pegarás... y seguirás siendo novato toda la vida Y pregunta aquí mismo si tienes alguna duda. |
#3
|
||||
|
||||
Cita:
Saludos |
#4
|
||||
|
||||
Bien, pon tu código que lo vayamos viendo y ayudando.
|
#5
|
||||
|
||||
Esto es lo que tengo hasta ahora, esta incompleto, como lo termino? |
#6
|
||||
|
||||
Yo lo resolvería por SQL, con una subselect. El valor de número vendria de:
*Sin conocer tu esquema de base de datos puede que en el where falte alguna condición. La idea es conseguir el mínimo número que te interese en esta select. Si tu motor de base de datos admite subselects en un update lo puedes juntar: En caso contrario deberías averiguar primero el mínimo y luego llamar a tu query.
__________________
Mallenat |
#7
|
||||
|
||||
en resumen tengo esto:
Pero estoy recibiendo el error de parametro "fecha" no encontrado. |
#8
|
||||
|
||||
Revisa el valor de la propiedad QTemp.Connection
|
#9
|
||||
|
||||
El código no da error pero en la base de datos no pasa nada
|
#10
|
||||
|
||||
Abre el programa que uses para gestinar las bases de datos y ejecuta el sql desde allí, "juega" haciendo cambios para comprobar qué registros cumplen la condición.
Ahí no podemos ayudarte mucho si no podemos probar con tu base de datos. |
#11
|
||||
|
||||
anexo la base de datos y los archivos delphi? para que hagan pruebas?
|
#12
|
||||
|
||||
Solucion Temporal
Saludos, Yo de nuevo, fabrique una solución poco ortodoxa porque no se me ocurrió nada mas para resolver esto , si tienen alguna observación me gustaría saberla, Gracias.
Tuve que crear un campo autonumerico que denomine "Cod" para que tuviera un valor único y así luego poder hacer el UPTADE a ese único registro. Cualquier sugerencia sera bien recibida. Gracias. |
#13
|
|||
|
|||
Hola EdwardFeliz, la verdad es que no entiendo porque la sentencia con la subselect no te funcionaba a no ser que no existiera clave primaria en esa tabla, ya que en Access los updates con subselect no funcionan bien en estos casos. La opción que has tomado es buena, desde mi punto de vista toda tabla debe tener un campo de clave primaria única lo que si me salta a la vista es que en la consulta con subselect no tenías en cuenta que el estado fuera pendiente, sin embargo, en esta segunda versión si la tienes.
|
#14
|
||||
|
||||
Cita:
Y lo del "Estado" lo agregue ya que había logrado hacer el Update, lo vi necesario porque así daba mas detalles para especificar el registro a actualizar. |
#15
|
||||
|
||||
Creo que necesitas reordenar tus ideas, y explicarnos claramente la situación, para que podamos ayudarte eficazmente.
|
#16
|
||||
|
||||
Cita:
"la idea es actualizar la tabla cuotas, el update lo que hace es introducir la fecha de pago, cambiar el contenido del campo "Estado" (que por default esta "Pendiente") a realizado, y el campo "Mora" ser actualizacon con el contenido de un edit, ¿Como saber sobre cual registro hacer esto? Va a Buscar en cuotas el registro que en el campo "NumPrestamo" contenga el numero del prestamo que esta en un edit, y el estado en "Pendiente", como esta consulta devuelve varios resultados iguales pero con la diferencia que existe otro campo que tiene el nombre "Numero" donde identifica el numero de la cuota (1,2,3,etc), va a elegir el registro que contenga el valor mas bajo en "Numero". Saludos! |
#17
|
||||
|
||||
Entonces lo indicado antes debe funcionar perfectamente:
Por lo que echa un vistazo a tu base de datos para encontrar el motivo de que no te funcione. Imagino que access admitirá subselect, en caso contrario debería dar algún error, aunque tampoco es que me extrañara mucho que no lo acepte y que no avise. La otra forma es hacerlo por separado, obtener primero el registro con el menor numero y luego actualizarlo. Aunque no entiendo esto: Cita:
|
#18
|
||||
|
||||
Cita:
Cita:
Eso eso solo que en ves de ID le puse "Cod" |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
¿Una función en Delphi, puede devolver varios parámetros? | socger | Varios | 6 | 27-02-2009 18:00:07 |
¿Actualizar varios registros a la vez? Ayuda... por favor | georkis | PHP | 2 | 29-04-2008 22:56:38 |
Actualizar Vista de Tabla en varios ordenadores | juanma65 | Conexión con bases de datos | 2 | 14-07-2006 10:26:48 |
actualizar aplicacion cliente en varios puesto | VRO | Providers | 0 | 25-10-2005 18:00:49 |
Problemas con varios Parametros | Carlex | SQL | 7 | 13-08-2004 23:34:34 |
|