![]() |
![]() |
![]() |
![]() |
![]() |
FTP | ![]() |
![]() |
CCD | ![]() |
![]() |
Buscar | ![]() |
![]() |
Trucos | ![]() |
![]() |
Trabajo | ![]() |
![]() |
Foros | ![]() |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
![]() |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
![]() Hola gente, buen dia.
Una consulta, estoy haciendo una aplicación con sockets, ya tengo el servidor y el cliente. Del lado del servidor tengo la base de datos (firebird) los query, ibupdate y dataset provider. Del lado del cliente tengo los clientdataset y datasource. Todo anda bien, puedo insertar información etc etc. Lo que necesito ahora es poder desde el cliente invocar un procedimiento almacenado definido en la base de datos. Del lado servidor puse un ibstoredsproc apuntando al procedimiento y puse un datasetprovider y los comunico. Ahora no se como hacer del lado del cliente para poder invocarlo. Desde ya gracias y espero vuestra respuesta. ![]() |
#2
|
|||
|
|||
Hola rruffino,
Tienes varias formas para hacerlo. Una de ellas sería introducir en el commandText del ClientDataset la sentencia SQL directamente y posteriormente llamar al método "execute" del clientDataset.
Para ello, tendrías que tener habilitado el parámetro "AllowCommandText" en el DatasetProvider correspondiente. Otro método (quizás más apropiado) puede ser crear un método remoto en tu capa Intermedia (o SQL). Para crear tu método remoto, tendrías que ir tu capa intermedia o SQL, pulsar en el menú View y en la opción Type Library. Te aparecerá un cuadro de dialogo y tienes que buscar un botón cuyo Hint dice "New Metod". Le pulsas y te crea un nuevo método. Le das nombre y guardar el proyecto. Luego tienes que irte al código de tu capa intermedia y localizar un procedimiento con el nombre que has indicado en la opción anterior. En la implementación de dicho procedimiento, introduces el código que quieras. Puedes hacer la llamada al componente "ibstoredsproc" y ejecutar tu procedimiento en base de datos. En la parte cliente, para llamar a este método remoto, tienes que utilizar el SocketConnection así:
Si no lo has hecho nunca, puede ser algo confuso, pero cuando lo hagas un par de veces todo se ve más sencillo. Espero que te ayude. Un Saludo. |
#3
|
|||
|
|||
![]() Hola manuc, muchas gracias por tu respuesta. La verdad que me ha sido de mucha ayuda. Opté por la opción dos (metodo) y me funciona bien. Ahora, tengo del lado servidor el Query, el IBUpdateSQL y el DatasetProvider. Desde el lado del cliente el Datasource y el ClientDataset, mi problema es que no puedo insertar datos en esa tabla. Copio el código
El error se da cuando entra en el IF. Estoy asignandole valores a todos los campos, no veo nada raro. Si me puedes ayudar te lo agradecere. Saludos, Román.- |
#4
|
|||
|
|||
Hola Román,
¿Tienes interceptado el evento onReconcileError del clientDataset? Si no lo tienes, puedes poner esto en el evento onReconcileError del ClientDataset:
Y tendrás una idea más clara de porqué no se están insertando los registros. Dimé que error te lanza y vemos a ver porqué puede ser. Un saludo. Manuel. |
#5
|
|||
|
|||
Respuesta
Manuel, gracias por tu rapida respuesta. El error que me tira dice:
SQL Parse Error Parameter name expected. Me mató porque no tengo nada parametrizado, lo he verificado, salvo que el campo id_cobranza tenga algo que ver con el hecho de que usa un generador que tiene trigger y procedimiento almacenado en la base Gracias, Román.- |
#6
|
|||
|
|||
Hola Román,
La verdad es que no sabría decirte claramente el motivo de este error. Me huele a que puede estar relacionado con la configuración de tu IBUpdateSQL, en la capa intermedia. Utilizando Query, puede ser que no necesites (no estoy seguro de esto, tendría que probarlo) el IBUpdateSQL, ya que el DatasetProvider genera la sentencia SQL que se ejecutará directamente en el Query (insert, updates, etc). Digamos que el DatasetProvider, no hace un .edit sobre el Query, sino, que envía una sentencia Update con la acualización de campos y su sentencia Where correspondiente. Yo probaría a revisar la configuración del ProviderDataset, del Query y del IBUpdateSQL. Cuéntame cómo te fue. Un saludo. Manuel. |
#7
|
||||
|
||||
otra opcion
Hola, aqui les dejo un ejemplo de como manejo los Procedimientos Almacenados, en DataSnap, espero les sea de utilidad.
![]()
Esto es en el cliente, creando los parametro y al mismo tiempo asignandole valores, si utilizas consultas, puedes utilizar FetchParams para recuperar los parametros, pero en los procedimientos almacenados no los recupera, por eso hay que crearlos 'a patín'. Ya que utilizas Firebird te comento, yo me tope con el problema de que agregaba los registros hasta que cerraba mi aplicacion, entonces para que guarde al instante utilicé la siguiente solucion. En el evento AfterExecute del DatasetProvider que se encarga de 'publicar' el IBstoredProc del servidor puse esto.
Espero le sirva a alguien, Saludos desde México. Felicitaciones a los compañeros españoles por el triunfo de su seleccion!!! ![]() ___________________ "El futbol Refleja el crecimiento de un pais"
__________________
Nadie puede separar su fe de sus actos, o sus creencias de sus afanes |
#8
|
||||
|
||||
![]() Cita:
desde ya muchas gracias! Slds. |
#9
|
||||
|
||||
Por favor, Jere_84, esa pregunta no tiene nada que ver con el título de lo que se trata en este hilo, si tienes una pregunta que hacer, crea un nuevo hilo, no mezclemos las cosas, gracias.
Guía de estilo
__________________
La otra guía de estilo | Búsquedas avanzadas | Etiquetas para código | Colabora mediante Paypal |
#10
|
|||
|
|||
Hola,
Casimiro Notevi, espero que no te moleste que conteste. Creo que en cierto modo sí está relacionado con el contexto inicial del hilo. ![]() Jere_84, Esto suele ocurrir porque el proyecto que tienes activo no es la capa intermedia (en el caso que hablábamos en el hilo se refería a un Remote Data Module) ¿Puede ser que tengas activo el proyecto exe cliente? Espero que te ayude y que no moleste a nadie :-) Un saludo. |
#11
|
||||
|
||||
Gracias!
Cita:
![]() Gracias = Última edición por Jere_84 fecha: 22-06-2012 a las 13:16:34. |
![]() |
|
|
![]() |
||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Procedimiento almacenado | Ledian_Fdez | SQL | 0 | 03-03-2010 15:38:18 |
procedimiento almacenado | JAI_ME | Varios | 5 | 02-09-2008 16:24:58 |
Procedimiento Almacenado | egostar | Firebird e Interbase | 4 | 15-12-2006 02:04:07 |
Procedimiento Almacenado | pichi Vignola | Firebird e Interbase | 2 | 17-08-2006 01:07:38 |
procedimiento almacenado | haron | Firebird e Interbase | 2 | 29-09-2003 01:09:56 |
![]() |
|