![]() |
![]() |
| Paypal | FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
|||||||
| Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Buscar | Temas de Hoy | Marcar Foros Como Leídos |
![]() |
|
|
Herramientas | Buscar en Tema | Desplegado |
|
|
|
#1
|
|||
|
|||
|
Te cuento..he ejecutado todas las partes por separado y no hay ningún problema, las ejecuta todas correctamente, sin errores y con los resultados correctos.
Junto dos partes y no hay problema, junto 4 partes y nada, pero cuando pongo 5 partes, salta el error. No sé si es que en ese momento el TQuery se satura o que.. No es un trozo de código concreto el que falla, sino cuando lo pongo todo junto y hay demasiado. Por eso creo que es algo de que el TQuery se vuelve loco con tanta consulta o que tiene X carácteres permitidos y salta el error, o algo de memoria. Porque si fuera el sql al ponerlas por separado también fallarian, y no es ningún fragmento en concreto. |
|
#2
|
||||
|
||||
|
¿De cuantos caracteres hablamos? ¿Los has contado? ¿Cuantos tiene con 4 trozos y cuantos con 5 trozos?
__________________
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
|
||||
|
||||
|
Hola de nuevo nena_yei.
Sigue siendo muy ambiguo el tema, me hubiera gustado saber con que base de datos estás trabajando y con que componentes te conectas con ella... Pero a ver si esto te sirve: (Solution--IDSQL32.DLL and Access Violations) http://<a href="http://delphi.cjcsof...a=page%3D1</a> Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... Última edición por ecfisa fecha: 06-07-2010 a las 18:41:01. |
|
#4
|
||||
|
||||
|
Anduve lento en preguntar por la base de datos y los componentes....
Ya respondieron más arriba: Acces y TADOQuery.. ![]() Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
|
#5
|
|||
|
|||
|
Este enlace pinta muy bien! Pero no sé muy bien como aplicarlo.. Lo del CustomConstraint lo tengo que poner en el componente TQuery donde hago el open y falla? En la propiedad Constraints pongo lo de FIELD IS NOT NULL?
Muchísimas gracias, espero que me expliqueis un poco como hacerlo y que sea la solución! ![]() Un saludo |
|
#6
|
|||
|
|||
|
Suena surrealista y yo soy la primera en sorprenderme en el número de carácteres de la consulta..pero he copiado la consulta en el word (despues de almacenarla en un Archivo.txt tal y como me explicasteis) y la consulta con 4 bloques son 26864 carácteres y no falla y la de 5 bloques son 33947 carácteres. No sé si el problema viene cuando pasa de 30000.
La consulta es así de larga porque es una aplicación que está creando una universidad, el departamento de filología hispánica, y la consulta lo que hace es buscar un conjunto de condiciones que indica el usuario dentro de muchos registros, entonces por ejemplo la consulta que estoy ejecutando alctualmente es cuando el usuario pone que quiere buscar: (árbol o arbusto) Y España. Y claro..el problema es que tiene que buscar la palabra árbol pero que tiene que encontrar todas las palabras árbol que estan seguidas de cualquier signo de puntuación, entonces he tenido que hacer "parches", una condición para cada tipo.. en plan: "tabla.campo like "% ('+palabra+' %" OR tabla.campo like "%''('+palabra+' %" OR tabla.campo like "% ('+palabra+') %" or ...." Y así teniendo en cuenta un montón de combinaciones con símbolos. Intenté hacerlo con expresiones regulares, pero se ve que en Delphi no se puede con sql, porque intente convertir una consulta que tenía en Acces para que funcionara a través del TQuery y no hubo manera (como "tabla.campo like "%[^a-z]'+palabra+'[^a-z]%"). Así que no me quedó más remedio que hacer todos los parches, entonces la consulta queda infinita, pero son los parches que ha indicado y que necesita el cliente. Es desesperante.. Qué puedo hacer?He probado de poner en el TQuery eso de FIELD IS NOT NULL en el Constraints pero no da resultado, sigue fallando, leyendo bien el link pone esto: The bug occurs and is reproducable by just setting one DefaultExpression on any DataSet. Y no debe ser el caso por el que salta mi error. Gracias, un saludo |
|
#7
|
|||
|
|||
|
Más pistas.. acabo de quitar varias condiciones de cada bloque y he probado con 5 y NO me ha saltado el error! Y he mirado el número de carácteres y son 28163, ahora voy a ir descomentando las condiciones que he comentado temporalmente para ver si realmente el problema son los 30000 carácteres.
Ahora os informo. Gracias de nuevo |
|
#8
|
|||
|
|||
|
Con la consulta con 31832 carácteres funciona sin problema, sin embargo, si añado algunas condiciones más y la consulta pasa a tener 33092 entonces salta el error. Con todas estas comprobaciones..creo que está claro que el problema es que el TQuery se vuelve loco cuando la consulta tiene más de 32000 o 33000 carácteres. Como podría solucionarlo? Fragmentar la consulta me seria casi imposible, porque son condiciones que tienen que estar enlazadas. Todo esto se arreglaría si pudiera utilizar expresiones regulares en la consulta sql
![]() Alguna sugerencia? Gracias, un saludo |
|
#9
|
||||
|
||||
|
Yo más que por 30000 caracteres apostaría por: 2^15=32768 caracteres.
No se qué consulta estás generando y si es correta, pero hasta cierto punto tiene lógica. Pensar que una consulta va a ocupar más 400 líneas de texto (32000 caracteres a unos 80 caracteres por línea) tampoco es descabellado. ¿Exactamente qué estructura tiene tu consulta? ¿Cómo puede ser que estés generando una consuta de 400 líneas? ¿Puedes explicar qué condiciones estás utilizando? ![]() ![]() ![]()
__________________
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. |
|
#10
|
||||
|
||||
|
Ok, este mensaje no lo había leído antes de mi última respuesta.
Cita:
Dejando este comentario aparte, creo que hay otra solución, que te puede resultar más rápida. Cita:
Bueno, lo más sencillo y rápido, es utilizar esa misma consulta (por ahora). No se si sabes que utilizando ADO puedes utilizar o llamar a las consultas que tienes almacenadas en Access. Para ello síolo tienes que usar el componente de TADOStoredProc y llamar a esas consultas como si fueran procedimientos almacenados. A parte de esto, comentar 2 cosas: 1º) Si hubieras explicado de principio algo más sobre esta consulta, seguramente hubiéramos llegado antes hasta aquí. 2º) Supongo que esto te funcionará, de todas formas creo que deberías replantearte algo el diseño y la estrucura de los datos; Teniendo en cuenta las consultas a las que tienes que atender. Un saludo. Ya dirás si te ha funcionado.
__________________
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. |
![]() |
| Herramientas | Buscar en Tema |
| Desplegado | |
|
|
Temas Similares
|
||||
| Tema | Autor | Foro | Respuestas | Último mensaje |
| Problema con ejecucion de consulta SQL por codigo (Firebird) | Cheerpipe | Conexión con bases de datos | 2 | 10-10-2007 18:05:20 |
| Problema con ejecución de DTS | grotero76 | Conexión con bases de datos | 4 | 20-09-2007 20:05:07 |
| Problema con ejecucion | tal0 | Varios | 2 | 07-08-2007 09:07:59 |
| Error en Consulta de tablas creadas en tiempo de ejecucion | javicho_villa | Varios | 1 | 02-02-2006 17:14:28 |
| Problema De Ejecucion | delphicano | Conexión con bases de datos | 4 | 14-05-2003 13:54:55 |
|