![]() |
¿Búsqueda SQL por Fecha?
Saludos amigos foristas....
el problema que tengo es que no se como ordenar una búsqueda sql por fecha tengo un formulario con un radiogroup que tiene varias opciones para ordenar en el mismo formulario tengo un dbgrid en el cual se muestra el resultado obtenido de el boton presionado del radiogroup y lo que escribi en el edit1.text pero necesito hacer un boton en ese radiogroup que se llame FECHA y necesito que haga lo siguiente: cuando yo seleccione la opcion FECHA y en el edit1.text coloque xx/xx/xxxx en el dbgrid se muestren los registros que tengan esa fecha mientras que toque ordenar por cadena de caracteres todo bien pero necesito saber como lo ordeno por la fecha escrita en el edit1.text!! gracias Adelantadas!! |
|
el campo por el cual quiero ordenar los registros se llama fec_ini es de tipo DATE y da error el código que me acabas de facilitar
mi tabla se llama db dice is not a valid date osea que no es una fecha valida y el código adaptado a mi programa quedó así
¿en que estoy fallando? |
Estoy intentando con este otro código y tambien da error:
:confused: |
intenté tambien con:
pero sigue sin funcionar :( |
Quizas no lo entiendo, pero si quieres ordenar deberias agregar una instruccion "order by" en tu sentencia sql, para que te lo ordene por los campos que quieres, en tu caso por fecha. Lo que estas haciendo con el "where" es solo limitar los registros que seleccionas.
|
Prueba este otro a ver si te vale:
Código Delphi [-]Query1.SQL.Clear; Query1.SQL.Add('SELECT * FROM db'); Query1.SQL.Add('WHERE fec_ini='+QuotedStr(Edit1.Text)); Query1.SQL.Add('ORDER by fec_ini'); Query1.Open; espero te sirva. |
No indicas que Base de Datos utilizas.
Hay algunas bases de datos que precisan que le pases el parámetro de la fecha en formato 'mm/dd/yyyy' y puede que por ahí venga el fallo que te indica que no es una fecha válida. Por otro lado, deberías por supuesto realizar una comprobación previa de que lo que se inserta en el TEdit corresponde a una fecha válida y en los formatos aceptados por tu Base de datos. |
El error viene dado debido a que lo que ingresaron en el edit1 no es una fecha valida. deberias validar antes de ejecutar la sentencia, y el primer ejemplo que te di te ahorras comprobar el formato de la fecha tal cual lo dice Gluglu.
|
|
sigo sin entender porque muchos quieren manejar fechas utilizar Tedit cuando pueden utilizar TDateTimePicker....
|
Cita:
|
gracias paladincubano tu código porfin resuleve la mitad de mi problema por que si ordena por fecha los registros pero
cuando voy al edit para escribir la fecha xx/xx/xxxx da error solo con pulsar cualquier tecla pero me imagino que ya es mas facil de resolver vuelvo a facilitar el código que uso para que porfavor me ayuden a completarlo gracias adelantadas :D
y para los amigos que sugieren el datetimepicker no lo uso por que ni siquiera sabia que existia y no tengo ni idea de como se usa pero si tienen una solucion con el datetimepicker es bienvenida gracias por su tiempo!! |
Cita:
Salud OS |
porfa ayundeme :(!!
|
Te toca investigar el uso del DateTimePicker1, y para que veas que no soy malo, ese objeto está en la pestaña Win32 ;) Salud OS |
sigue dando error :(
dice 'type mismatch in expression' este es el código que tengo espero me ayuden a conseguir mi falla
el radiobutton 0 es el que dice fecha el resto de opciones van a la perfeccion Gracias adelantadas!! |
A ver, dime una cosa, que tipo de campo es fec_ini, Date o String;
Salud OS |
fec_ini es tipo Date
tabla paradox 7 y uso delphi 7 Gracias! |
Cita:
Si no funciona y te sigue mandando error tal vez es el formato de fecha corta que esta usando la db, pero eso lo podrias resolver poniendo esta linea:
Prueba con ambas en caso de que no te funcione. Salud OS |
Solucionado!!
Gracias egostar por el código proporcionado, para que funcionara como yo deseaba lo inserte en el evento onchange del datatimepicker y funcionó de lujo Muchas Gracias de Verdad a todos los que intentaron ayudarme!! |
jeje, que pasa con los cubanos man??? aqui hay uno 100% de pura cepa... lo que pasa es que he tenido que emigrar para Espana.
saludos a todos los cubanos de por aqui. |
Cita:
Salud OS PD. por supuesto que no tengo nada en contra de ningún cubano, para mi todos somos amigos del mismo planeta :rolleyes::) |
SQL con fechas y Access
Hola,
Yo también tengo un problema con una query que lleva fecha. SQL.Add(' AND (Entrada_Fx = :fecha') El componente que utilizo es un DateTimePicker y intento adaptar las soluciones que aqui se proponen a mi código pero me da el siguiente error: EOLEException falta ), ] o elemento en la expresión de consulta ' AND Entrada_Fx= ?" Entrada_Fx es un campo de tipo Fecha/corta (Access). Estoy intentando pasar por parametro de la siguiente forma: Parameters.ParamByName('fecha').value:=(RE_DTP_In.Date); antes de ejecutar la query ¿que hago mal? Gracias |
|
Gracias, se nota la poca experiencia que tengo.
Ya he arreglado lo del parentesis pero ahora me dice que "parameter fecha not found". He revisado los foros sobre este tema pero no encuentro el error , he borrado el parametro y lo he vuelto a definir pero sigue igual Despues de definir la query hago: AQr_Entrada.Parameters.ParamByName('fecha').Value:= (DTP.Datetime); Tengo definida en AQr_Entrada el parámetro fecha con las siguientes opciones DataType:ftDateTime(si pongo ftDate cambia automáticamente a ftDatetime) Direction:pdInput Value:01/01/1900 Donde puedo tener el error? Gracias |
Hola, intenta con lo siguiente:
Saludos. |
Antes de nada gracias por responder tan rapido,
he probado como me indicas AQr_Entrada.Parameters.ParamByName('fecha').AsDateTime := DTP.Datetime; Me da el siguiente error: Undeclarer identifier "AsDateTime" si se os ocurre otra cosa o en donde puedo estar metiendo la gamba... |
Cita:
Saludos. |
Me da el mismo error
Undeclarer identifier"AsDate"... |
Hola, estas seguro que el campo es de tipo DateTime?. que viene siendo DTP un datetimepicker?
Saludos. |
solo para estar seguros, porque no colocas el codigo que estas utilizando en estos momentos...
|
Hola,
Exactamente DTP es datetimepicker, disculpa no especificar antes. En la aplicación trabajo con ellos, leo datos, guardo el problema surge cuando quiero buscar por el campo fecha. Lo primero que he intentado es algo que también he visto en foro SQL.Add(' AND (Entrada_Fx >='+DateToStr(d6)+')'); siendo d6:Tdatetime; y asignandole con anterioridad d6:=DTP.Asdatetime, y realmente funciona, la query trae los registros con la fecha igual o mayor. Pero yo quiero realmente solo los del dia. Como con = no funciona pensé, a este lo pillo yo y empecé a probar con dos fechas y between o con >=hoy y <mañana, pero resulta que lo de < tampoco me funciona. Vi en el foro la solucion del pasar por parametro y ahi es donde me encuentro, pero ahora que no me quiere el parámetro. Como ya os dije en otros hilos soy muy novata en esto de programar y en delphi más asi que será cualquier tontería pero el caso es que no la veo... |
¡¡Creo que lo solucioné!!
Antes de nada, perdon a eduardocol, no me dio tiempo a leer tu mensaje y perdon por la tardanza, pero tardo tanto en escribir el mensaje que me caduco la sesion y volver a empezar ..... d6:=DTP.asdate RgEntrada.SQL.Text:='SELECT *' +'FROM RgEntrada' +' WHERE True'; for i:=1 to finarray do begin if cadenaBusqueda[i] then begin case i of 1:SQL.Add(' AND (Tipo LIKE"'+'%'+(s1)+'%")'); 2:SQL.Add(' AND (Procedencia LIKE"'+'%'+(s2)+'%")'); 3:SQL.Add(' AND (Remitente LIKE"'+'%' +(s3)+'%")'); 4:SQL.Add(' AND (Contenido LIKE"'+'%'+(s4)+'%")'); 5:SQL.Add(' AND (Archivo='+IntToStr(i5)); 6: SQL.Add(' AND (Entrada_Fx = :fecha)') ; ..... end; end; end; RgEntrada.Parameters.ParamByName('fecha').Value:=DTP.asdate; ExecSQL; Open; Hay dos errores 1:si no pongo nada en el campo entrada del FORM no entra en la opción6 y no encuentra el parametro fecha. "Parameter fecha not found". Solucion:poner esa línea solo si entra en la opcion 6. 2-si pones dato no encuentra nada, porque las propiedades de los componentes del form no estan accesibles. Solucion: guardarlas anteriormente en variables y pasarle estas a la query Quedaría 6:begin SQL.Add(' AND (Entrada_Fx = :fecha)') ; RgEntrada.Parameters.ParamByName('fecha').Value:=d6 end; Me he explicado o me he liado... Bueno ahora a pelearme con Access y Multiusuario, pero eso ya es otro hilo, mejor dicho eso es la madeja entera. Gracias y hasta pronto |
| La franja horaria es GMT +2. Ahora son las 07:39:43. |
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