FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
||||
|
||||
Resultado de un Execute con DBxpress
Buenos dias, ha ver si me podeis hechar una mano.
Como en cualquier programa, se usan sentencias sql para trabajar con firebird, por ejemplo Cuando se genera un error en la sentencia, except me devuelve el error y tal, pero, si por ejemplo la sentencia sql es 'UPDATE CIUDADES SET ALCALDE='MALO' WHERE SUELDO>10000' ¿Como se cuantas filas se ven afectadas? parece que hay un componente TSQLDataSet.ExecSQL que devuelve el resultado sobre el numero de filas afectadas, pero no encuetro la solucion usando DBxExpres (dbxfb4d14.dll y fbclient.dll) ¿Alguna idea? Gracias
__________________
Disfruta de la vida ahora, vas a estar muerto mucho tiempo. |
#2
|
||||
|
||||
Siempre puedes lanzar la sentencia equivalente para contar, antes del UPDATE (con el mismo WHERE):
__________________
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. |
#3
|
||||
|
||||
Si, es un buen truco, pero a la pregunta formulada no hay respuesta, es decir dbxexpress no devuelve un resultado salvo en
Por preguntar ¿eh? Pero, ¿Que pasa si la sentencia sql viene de un campo TMemo? Vamos, lo que he hecho ha sido porner un TMemo y un boton, entonces queda En realidad no se que sentencia voy a escribir, esto lo hago para borrar registro "sucios", etc.
__________________
Disfruta de la vida ahora, vas a estar muerto mucho tiempo. Última edición por cesarsoftware fecha: 20-03-2013 a las 12:34:07. |
#4
|
||||
|
||||
Supongo que en ese caso dependería de si el SGBD devuelve esa información y si los componentes permiten recuperarla.
Siento no poder ayudarte más.
__________________
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. |
#5
|
||||
|
||||
Gracias neftali, creo que los componentes dbxpress no devuelven nada, segun lo que leido en los manuales, por eso preguntaba, sniff
__________________
Disfruta de la vida ahora, vas a estar muerto mucho tiempo. |
#6
|
||||
|
||||
Otra opción es hacerlo todo por procedimientos almacenados, y que estos procedimientos tengan un parámetro de salida con el resultado
Por dar "soluciones" que no quede :P
__________________
La Madurez se llama... ~~~Gaia~~~ |
#7
|
||||
|
||||
Me has "pillado", y eso ¿como se hace ozswizzard?
__________________
Disfruta de la vida ahora, vas a estar muerto mucho tiempo. |
#8
|
||||
|
||||
La verdad es que no he pensado muy bien mi mensaje anterior, estaba en plan coña pero me imagino lo siguiente:
Los motores de bases de datos más usados y con cierta base para plantear lo que se quiere hacer (sql server, mysql, firebird, oracle, etc) sueles tener una ejecución de sentencias por variable de tipo cadena, es decir, una cosa así:
Y, seguramente, desde el propio motor debe ser relativamente fácil saber que devuelve esa ejecución. Esa es la idea gorsso modo
__________________
La Madurez se llama... ~~~Gaia~~~ Última edición por ozsWizzard fecha: 20-03-2013 a las 14:01:19. |
#9
|
||||
|
||||
Ese es el problema, que no se como recuperar esa informacion de estado.
__________________
Disfruta de la vida ahora, vas a estar muerto mucho tiempo. |
#10
|
||||
|
||||
Mira a ver si te vale este enlace, en lo que respecta a row_count
http://www.firebirdmanual.com/firebi...es-firebird/40 Puedes preparar un procedimeinto almacenado que te devuelva el nº de registros afectados. Seguramente puedas hacerlo desde el excute script añadiendole la sentencia que devuelve el nº de registros afectados. Un saludo ROW_COUNT DESCRIPCION:La variable de contexto ROW_COUNT contiene el número de filas afectadas por la declaración más reciente DML (INSERT, UPDATE, DELETE, SELECT o FETCH) en el gatillo actual, el procedimiento almacenado o bloque de ejecución. TIPO RESULTADO: INTEGER EJEMPLO: update Figures set Number = 0 where id = :id; if (row_count = 0) then insert into Figures (id, Number) values (:id, 0); FUNCIONAL EN: PSQL AGREGADA EN: Versión Firebird 1.5 MODIFICADA EN: Versión Firebird 2.0
__________________
Cuando los grillos cantan, es que es de noche - viejo proverbio chino - |
#11
|
||||
|
||||
A ver si leemos la documentación
Cita:
|
#12
|
||||
|
||||
A ver si la ponen bien para que la leamos.
Saludos
__________________
Cuando los grillos cantan, es que es de noche - viejo proverbio chino - |
#13
|
||||
|
||||
No había visto tu respuesta
|
#14
|
||||
|
||||
PEnsaba que te referías a mi comentario, por eso he respondido.
De todas maneras, el link que pongo es a la página oficial de Firebird, de ahí que me sorprenda que no esté toda la información que tú aportas. Es importante el matiz de los valores que devuelve row_num para ver que no le vale a nuestro amigo. Saludos
__________________
Cuando los grillos cantan, es que es de noche - viejo proverbio chino - |
#15
|
||||
|
||||
#16
|
||||
|
||||
Esto...., una cuestion a los espertos,
Cuando ejecutais una sentencia cualquiera en sql, os fiais siempre de que ha hecho lo que quereis, o teneis algun truco, quiero decir. Si ejecuto SQLconnection.execute('SELECT * FROM CIUDADES', nil, @DataSet) en DataSet tengo el resultado de la consulta, aunque sea 0, pero si ejectuto SQLconnection.executedirect('UPDATE CIUDADES SET ALCADE='MALO' WHEN SUELDO>10000'), ¿como sabeis que ha hecho algo o lo ha hecho bien? yo suelo poner un try, except pero solo funciona cuando la setencia sql esta mal escrita, pero si esta bien y "no hay ningun alcalde malo" no me entero de que o no ha hecho nada o de que todos los alcaldes son malos. Vale, si, podria hacer un count previo y otro posterior, pero, seguro que hay algo que resuelva esta cuestion PD: LJM (Leete el Jodido Manual), ya si ya me he estudiado "parte" del manual y hasta tengo varios libros de sql, aunque, ¡os necesitooooo!
__________________
Disfruta de la vida ahora, vas a estar muerto mucho tiempo. |
#17
|
||||
|
||||
Porque lo hace bien, no hay duda, hace exactamente lo que se le dice.
Otra cosa distinta es que no haya hecho lo que tú esperabas, pero eso ya es fallo de uno. |
#18
|
||||
|
||||
Correcto casimiro, firebird es muy bueno, reconozco que no soy experto en sql, uso sql (bueno firebird) desde hace unos pocos años y siempre, siempre me he fiado de el y nunca me ha fallado.
Pero estaba hasta los webs de usar programas de terceros para ver el contenido de tablas, borrar registros "sucios", cambiar un valor para hacer unas pruebas, etc. Asi que desde hace un par de proyectos incluyo un pequeño manejador de la tablas de la base de datos, donde puede añadir tablas, indices, campos, cambiar campos, etc. y ahora le he añadido ese memo para hacer cositas, tipo filtro para ver los registros pero solo de una fecha o borrar algo, etc. y es ahora cuando he visto que estaria bien si se pudiera tener ese "log" de resultado. ¿Como haceis vosotros? usais programas tipo IBQ u os lo "currais a pelo". ¿Por preguntar eh?
__________________
Disfruta de la vida ahora, vas a estar muerto mucho tiempo. |
#19
|
||||
|
||||
En todo caso, conectas con ibexpert o flamerobin... y listo. ¿Para qué complicarse la vida?
|
#20
|
||||
|
||||
No me jo... no me digas que me estoy complicando la vida usando dbxpress, era con el que empece (creo que por dephi 2005) despues de abandonar las tablas BDE y me costo encontrar la libreria para delphi 2010, porque creo, ya no me acuerdo, que en alguna version delphi se desprendio de los componentes dbxpress para atacar a interbase/firebird y me tuve que "buscar la vida" y encontrarlos "por ahi".
Si tuviera todo el tiempo del mundo...igual me leia todos los mensajes de las zonas de este foro y a lo mejor, encontraria el componente ideal, pero casi siempre es mejor usar lo que uno "domina", pero acepto sugerencia para cambiar.
__________________
Disfruta de la vida ahora, vas a estar muerto mucho tiempo. |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Problema file not found dbxpress.dcu | liito16 | Varios | 3 | 28-09-2012 05:18:56 |
Problemas con dbxpress en dll | mcsebas | Conexión con bases de datos | 3 | 05-08-2010 08:33:04 |
Busqueda en SQL Server con dbxpress | mbcito | SQL | 1 | 10-11-2005 16:42:43 |
problema con delphi7,firebird 1.5 y dbxpress | Eskema | Conexión con bases de datos | 2 | 27-07-2005 13:22:52 |
donde poner los componentes dbxpress | wonder boy | Conexión con bases de datos | 5 | 23-03-2004 15:25:51 |
|