![]() |
![]() |
![]() |
![]() |
![]() |
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
|
|||
|
|||
Problema busqueda varios campos
BASE DE DATOS: MYSQL
DELPHI 5 Que tal? .. quiero hacer la busqueda de varios campos. Primero quise realizar la busqueda por medio de un Query ... usando un ADOQuery ... el problema es que tengo un datetimepicker que guardo la fecha en formato DD-MM-AAAA ... para insertar la fecha hago una conversion, ya que MYSQL permite el formate AAAA-MM-DD ... entonces cuando lanzo un SELECT no me devuelve NADA porque el formato de la fecha se manda como DD-MM-AAAA ... y la propiedad ADOQuery.SQL.ADD('') no me permite realizar la conversion de formato. ENTONCES COMO HAGO'? Se me ocurrio hacer la busqueda con un LOCATE. Pero resulta que la busqueda la tengo que hacer preguntando varios campos (mi tabla a consultar tiene multiples llaves primarias), y mi problema es que no se como se hace Lei que hay que mandar una variable, asi como Table.Locate('Mes;Dia',VarArrayof([Mes,Dia]),[]) ... pero no tengo idea como se crea el array y como se le asigna valores. Mi idea seria crear el Array, y mandarle como valor lo que hay en un edit. Por ej Variable1:=Edit1.text Variable2:=DateTimePicker1.date Variable3:=strtoint(Edit2.text) Algo asi pienso que es, como se hace esto en un array para mandarlo como parametro a un LOCATE?? GRACIAs. |
#2
|
||||
|
||||
Hola elrodrix y bienvenido a Club Delphi
![]() Como a todos los que se inician te invitamos a que leas nuestra guía de estilo. Saludos y gracias por tu colaboración.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#3
|
|||
|
|||
Muchas gracias. Mientras voy leyendo no podrias aunque sea tirar una idea de como podria solucionar mi problema? ... saludos
|
#4
|
||||
|
||||
Cita:
![]() Quizá sólo te falta hacer la conversión al formato 'yyyy-mm-dd' usando la función FormatDateTime. ![]() |
#5
|
||||
|
||||
Tal como lo menciona Al_Gonzalez....
Como ejemplo con un DateTimePicker y un Boton en el boton pones el formatDateTime:
Con esto le das el formato que quieras a tu fecha, muy bueno para trabajar con base de datos por ejemplo MYsql y Sql Saludos! |
#6
|
|||
|
|||
Cita:
|
#7
|
||||
|
||||
SQL no es ninguna base de datos, es un lenguaje.
__________________
La otra guía de estilo | Búsquedas avanzadas | Etiquetas para código | Colabora mediante Paypal |
#8
|
|||
|
|||
Hola
La función Locate sería así: Código:
if Table1.Locate('Campo1;Campo2;Campo3',VarArrayOf([Valor1,Valoe2,Valor3]),[]) then //Encontrado Para hacer una condición por varios campos se usa el operador AND Código:
where Campo1='xxxx' And Campo2>10 And Campo3=200 And Campo4<>'1' Código:
function AnsiQuotedDate(Fecha:TDateTime):String; begin Result:=''''+IntToStr(Year(Fecha))+'-'+IntToStr(Month(Fecha))+'-'+IntToStr(Day(Fecha))+''''; end; Código:
Tabla1.ParamByName('Fecha').AsDate:=AnsiQuotedDate(DateTimePicker1.Date); Query1.SQL.Strings[3]:='Where Fecha='+AnsiQuotedDate(DateTimePicker1.Date); Bueno espero te sirva de algo esta información Saludos
__________________
Cancun, Q.Roo, México |
#9
|
||||
|
||||
No me di cuenta de mi error.... ![]() Ahora que leo de nuevo las definiciones de cada palabra... Lo diré de nuevo: Cita:
Cada vez aprendo más.... Gracias a ustedes... ![]() Saludos! |
#10
|
||||
|
||||
Cita:
![]()
__________________
La otra guía de estilo | Búsquedas avanzadas | Etiquetas para código | Colabora mediante Paypal |
#11
|
||||
|
||||
O quizá se refiere a Firebird SQL Server, que también es popular.
![]() |
#12
|
||||
|
||||
El departamento de marketing de Microsoft hizo una buena jugada en poner a su RDBMS de nombre "SQL Server", así todas las personas que no entienden mucho del tema piensan que "SQL server" es el de microsoft, y que el resto son "otra cosa".
Si llegan a ser fabricantes de coches, le ponen de nombre "coche" y así todo el mundo asocia "coche" con el MS coche ![]() Y los demás no son "coches", son vehículos a motor con 4 ruedas y volante, de nombre ford, renault, nissan, etc. pero el auténtico "coche" es el de microsoft, el "MS coche" ![]()
__________________
La otra guía de estilo | Búsquedas avanzadas | Etiquetas para código | Colabora mediante Paypal |
#13
|
||||
|
||||
Pues eso tiene sus antecedentes históricos desde que Estados Unidos decidió llamarse así, Estados Unidos de América. De esa forma identifican todo el continente con ellos, como se desprende de la doctrina Monroe.
No es de extrañar que sus empresas hagan cosas similares. // Saludos |
#14
|
||||
|
||||
Tienes razón, creo que el nombre oficial es "Estados Unidos Mexicanos", situado en América del Norte y que limita al norte con los "Estados Unidos de América".
Entonces México también es "Estados Unidos de América", porque está en América. Y entonces también es "norteamérica".
__________________
La otra guía de estilo | Búsquedas avanzadas | Etiquetas para código | Colabora mediante Paypal |
#15
|
||||
|
||||
En efecto, el nombre oficial de México es Estados Unidos Mexicanos. Tampoco es que nuestros fundadores hayan sido muy originales :s con eso de Estados Unidos. Pero al menos tenemos el apelativo México de antecedentes prehispánicos.
// Saludos |
![]() |
Herramientas | Buscar en Tema |
Desplegado | |
|
|
![]() |
||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Top con varios campos | trex2000 | MS SQL Server | 1 | 04-10-2006 21:12:15 |
Problema campos de busqueda | Luis Castillo | Firebird e Interbase | 7 | 06-01-2006 16:55:23 |
Problema campos de busqueda | Luis Castillo | Varios | 2 | 02-11-2005 10:47:31 |
campos de busqueda................. | David J. | Conexión con bases de datos | 3 | 06-07-2004 17:34:36 |
Busqueda por 2 campos a la vez | CJRE | SQL | 3 | 26-05-2004 18:48:36 |
![]() |
|