![]() |
Sentencia SQL desde Delphi con Cremillas
Hola a Todos...
Espero que el titulo sea el adecuado, y les cuento el error que tengo ejecuto una sentencia en el SQL Server y funciona super bien
Lo que hace la sentencia anterior es asignar a Num el valor actual del Campo Identidad de una Tabla (Tarjeta) si ejecuta la sentencia desde delphi 7, me da error, y se que son las cremillas que estan antes y despues de Tarjeta.... pero no se como ponerlas
Ahora la pregunta es como declaro las Cremillas dentro de una sentencia de SQL desde Delphi... Si le quito las cremillas si bien compila, me arroja error de ejecución... Salu2:D:p:confused: |
Por cierto, son comillas, no cremillas :) // Saludos |
Cita:
Yo hubiera pensado que se hacía así:
|
Sí. En delphi, para poner una comilla dentro de una cadena de texto, se pone dos veces. Pero también como tú lo propones se puede.
// Saludos |
Tnks Roman... ha... y sorry... ahora se llaman comillas.... ;):D
|
Cita:
|
Cita:
Saludos. :) |
Cita:
Un saludo. |
En el diccionario no viene cremilla, ni en ningún sitio que he mirado.
|
Cita:
Por cierto... ¿cremilla no es eso que nos echamos para el sol en la playa? :p |
Si, para evitar el sol, tan bonito que tenemos en españa.
|
Cita:
Saludos. :) |
Cita:
Las palabras que "suenan mal" son aquellas que se leen con prejuicios y las que se escriben con descuido. :) |
Por favor, si teneis un tema distinto del original deberiais de crear un hilo nuevo, ¿habéis leido ya la guía de estilo? :p:D
|
Cita:
Pues entonces, otra forma:
|
Cita:
Por otra parte es raro que no acepte comillas dobles, ¿qué servidor es? // Saludos |
Cita:
Saludos |
Cita:
// Saludos |
Cita:
|
Pues si usa sql estandar (más o menos), la conversión puede ser rápida :)
|
lo que si os aseguro es que:
1.- Que me equivoque de nombre... si se que son comillas, pero tuve un lapsus, asi que aún no se por que le puse Cremillas... 2.- la funcion 1 de Roman me funciono super.... poner 2 comillas simples juntas me sirvio. Salu2:p:D |
Cita:
1-Los triggers habría que rehacerlos totalmente porque el lenguaje cambia de forma radical y el problema no es desarrollarlos, es la depuración posterior. 2-El problema inicial era que la aplicación, al venir de usar bases de datos de escritorio está plagada de ttables por lo cual habría que buscar componentes de acceso a firebird que los contemplen, cosa que ya he hecho pero tendría que probar bien. La verdad es que antes de cambiar todo el desarrollo a esta base de datos contraté a un supuesto "guru" de delphi para que me cambiara los componentes a firebird, cosa que se hizo (bajo un presupuesto a mi parecer excesivo). El problema es que se usaron los componentes dbexpress (quiero recordar) para los ttable y como imagino que sabréis estos componentes lo primero que hacen es un select * de la tabla y con tablas grandes el programa se hacía inoperativo. Cuando le comento el tema a mi "guru" la respuesta fue "esto no es renault ocasión, no hay milagros". Por otro lado cuando trincó la pasta se "olvidó" de rematar el tema y empezaron los problemas así que opté por pasar de todo y cambiarlo yo personalmente a ElevateDB que tiene componentes propios y no me resultó excesivamente complicado hacer la migración. La ignorancia, algo después andando por aquí me di cuenta de que hay componentes de acceso a firebird a montones y muchos de ellos, sin importarme que fueran de pago tienen componentes ttable para el acceso a las tablas. Saludos |
Bueno, si necesitas un TTable, sólo tienes que usar un TIBDataSet y poner "select * from laTabla", ya tienes un TTable, que eso es lo que hacen todos, como ya sabes.
|
Cita:
|
Cita:
Abrir la tabla debe ser inmediato con todos, lo que ocurre es que algunos componentes tienen una propiedad para indicar si quieres que cargue todo en memoria o no. Evidentemente, si tiene que cargarlos todos, por ejemplo, haciendo un 'fetch' (ir al final .last) o contar los registros, será lento cuando tengas muchos registros. Pero todos trabajan igual, me explico, un componente Table es lo que he comentado antes, un Dataset que su sql pone "select * from tabla". No hay más, ni puede haberlo. En este hilo se habló sobre ese tema y aquí están los resultados: Zeos:
IBX:
MDO:
IBDAC
|
Pues con la base de datos que yo uso el tema de los ttable funciona exactamente igual que con bases de datos dbf, abres el ttable y directamente puedes pedir un recordcount, irte al final, etc de forma inmediata ya tenga uno o millones de registros. No sé, igual estoy confundido en algo pero funciona de esa forma.
|
Sí, bueno, para irte al final rápidamente puede tener, por ejemplo, un índice descendente. Pero de todas formas, salvo que sea una tabla muuuy grande y con muuuchos campos, será rápido siempre.
Y, por supuesto, un Ttable es un dataset con un "select *". Otra cosa que se me ocurre en tu caso es que esa base de datos use técnicas de bases de datos de escritorio, que almacena el tamaño de cada registro y multiplica por la posición del registro que quieres ir y accede directamente a esa posición en la tabla. Pero en ese caso no usaría registros de longitud variable. En fin, aunque he usado bases de datos dbisam, no conozco elevatedb. |
Bueno, la verdad es que no sé cómo van las tripas de estas cosas. Lo único que pude comprobar es que con las pruebas que hacía con firebird tardaba bastantes segundos en abrir una tabla de algunos miles de registros y eso me hizo desistir de esa vía, sin embargo con esto es todo igual que con los dbf.
|
Claro, es que es muy diferente usar unos componentes u otros, no es lo mismo zeos que fibplus, la diferencia en velocidad es bastante significativa.
Pero, de todas formas, ahora mismo yo aplicaría el famoso: "si funciona, no lo toques". Es lo mejor :) |
Cita:
|
Cita:
|
Cita:
|
Cita:
|
| La franja horaria es GMT +2. Ahora son las 09:44:13. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi