FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
Consulta en Tabla
Hola a todos.
Necesitaría un pequeño ejemplo de lo siguiente: Tengo una base de datos con una tabla. Dicha tabla tiene varias filas con 6 campos cada una. El primer campo de nombre "pregunta" y los otros 5 Respuesta1 a Respuesta 5. Lo que pretendo es iniciar una búsqueda por pregunta y al hallarla visualizar aleatoriamente 1 de las 5 respuestas. Estoy atascado en este tema y por ello agradecería enormemente un pequeño ejemplo para salir del atasco. Utilizo el Delphi 7 Gracias por vuestra atención. Saludos. Manuel Reixach |
#2
|
||||
|
||||
Hola Abuelo7, puedes utilizar la función Random.
Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar. |
#3
|
|||
|
|||
Cita:
Ante todo perdona el retraso en agradecer tu ayuda. Me ha quedado muy claro. He tardado tanto porque estoy batallando con una pequeña prueba pero no sé por que motivo no logro hacer lo que quiero. Se trata de lo siguiente: Tengo una tabla Paradox con 2 campos, (pregunta,respuesta).Ambos campos de texto. He creado un Form con lo siguiente: 1 DataSource 1 Table 1 Edit1 1 Edit2 1 Button para salir Necesito hacer lo siguiente: Al introducir un texto (pregunta) en Edit1 que busque en la tabla y si lo encuentra que aparezca la (respuesta) en el Edit2. He realizado un montón de intentos y me aclaro. Supongo que con la edad se me cruzan las neuronas. Agradecería mucho tu ayuda. Un cordial saludo. Manuel Reixach |
#5
|
||||
|
||||
en esencia es lo que dice Felipe pero para completar....
En principio el Datasource no te serviría para nada ya que no tienes ningún control que lo utilice yo utilizaría un Tquery y un database (entendiendo que accedes por BDE a la BD) con lo que nos quedaría: 1 button, 2 Edit, un query y un database El database lo apuntas a la bd y el query al database y
|
#6
|
||||
|
||||
Hola de nuevo Abuelo7, puedes utilizar la función Locate para buscar la pregunta, si la opción es loPartialKey te hara una busqueda aproximada si es loCaseInsensitive te hara una busqueda exacta sin tomar en cuenta mayusculas y minusculas.
Yo te aconsejo que utilises un query en vez un table, también trae la función Locate y se usa de la misma forma, ademas que tienes opción para hacer consultas. Una observación, no sería mejor que al usuario le permitieras escoger la pregunta en vez de que la escriba, porque si es una pregunta larga y no la escribe bien, no la encontrara. Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar. |
#7
|
|||
|
|||
Hola a todos.
Ante todo muchas gracias a vosotros por vuestra ayuda.Al fin lo conseguí. Lo he hecho como tú me decías amigo Caro. En cuanto a lo que me comentas de que el usuario escoja la pregunta, no es posible por una razón. Lo que estoy empezando a construir es un programa de IA, donde el usuario entrará una frase o palabra y el programa contestará, si encuentra, con alguna frase o palabra asociada. En principio tengo una tabla para hacer la prueba, que ha resultado bien, la tabla tiene 3 preguntas y tres respuestas. Buenos días, contesta--muy buenos Buenas tardes,contesta--buenas las tengas Hola, contesta--hola amigo. Esta prueba ha ido perfecta. Ahora lo siguiente es que tanto la entrada como la salida aparezcan en un ListBox, con lo cual el usuario irá viendo como va la conversación. Ademas y a ser posible en lugar de una respuesta, habrán varias, y que con un Randomize contestará una de ellas aleatoriamente. Bueno y muchas mas ideas que tengo para ir haciendo. Que os parece? Creo que no está mal para mis 70 años. Un cordial saludo. |
#8
|
||||
|
||||
Soy amiga, amiguito Abuelo7.
Sobre añadir al ListBox, tendras que hacerlo, una vez que encuentra la respuesta.
Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar. |
#9
|
|||
|
|||
Perdona amiga Caro.
Repito gracias por todo. Estupendo lo del ListBox. Ya te tendré al corriente de como voy desarrollando el tema. Saludos cordiales. Manuel Reixach |
#10
|
||||
|
||||
[quote=Caro]
Soy amiga, amiguito Abuelo7. [quote] Menos mal, me tranquiliza que yo no sea el único
__________________
Lo importante no es llegar primero, sino saber llegar. Para que puedas llegar mejor lee la Guia de Estilo |
#11
|
||||
|
||||
[quote=Caro]
Soy amiga, amiguito Abuelo7. [quote] Menos mal, me tranquiliza que yo no sea el único
__________________
Lo importante no es llegar primero, sino saber llegar. Para que puedas llegar mejor lee la Guia de Estilo |
#12
|
||||
|
||||
No eres el unico amiguito, solo ayer, en 3 hilos me han llamado amigo .
Ok Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar. Última edición por Caro fecha: 03-09-2008 a las 16:18:33. |
#13
|
||||
|
||||
Es lo que yo decia, con ese nik Si al menos pucieras un avatar más aclaratorio/descriptivo
__________________
Lo importante no es llegar primero, sino saber llegar. Para que puedas llegar mejor lee la Guia de Estilo |
#14
|
||||
|
||||
Abuelo, que tal una tabla de búsqueda para las preguntas y otra para las respuestas con una relacion de uno a varios, así por cada pregunta tienes x cantidad de respuestas y no tienen que ser solo cuatro, esto tiene la posibilidad de ir enriqueciendo las respuestas, porque tu programa me puede preguntar "como estás?", y yo le puedo responder, "aqui guapeando" y entonces el detectar que es una respuesta que no tiene y agregarla al arcenal de respuestas pocibles
Claro que eso es solo una idea más, el objetivo es no limitar a solo cuatro respuestas por preguntas y que el programa se retroalimente de las conversaciones. Saludos
__________________
Lo importante no es llegar primero, sino saber llegar. Para que puedas llegar mejor lee la Guia de Estilo |
#15
|
|||
|
|||
Hola amigos y amigas.
Respecto al tema que me está preocupando tengo lo siguiente: unit PruebaBuena4; interface uses Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls, Db, DBTables; type TForm1 = class(TForm) ListBox1: TListBox; Button1: TButton; DataSource1: TDataSource; Table1: TTable; EditPregunta: TEdit; procedure Button1Click(Sender: TObject); procedure EditPreguntaKeyPress(Sender: TObject; var Key: Char); private { Private declarations } public { Public declarations } end; var Form1: TForm1; implementation {$R *.DFM} procedure TForm1.Button1Click(Sender: TObject); begin Close; end; procedure TForm1.EditPreguntaKeyPress(Sender: TObject; var Key: Char); var respuesta : Integer; RespuestaCAD : String; begin If key=#13 then begin Table1.Open; If Table1.Locate('pregunta',EditPregunta.Text, [loCaseInsensitive]) then Randomize; respuesta := Random(5); Case respuesta of 1: RespuestaCAD := Table1.fieldByName('respuesta1').AsString; 2: RespuestaCAD := Table1.fieldByName('respuesta2').AsString; 3: RespuestaCAD := Table1.fieldByName('respuesta3').AsString; 4: RespuestaCAD := Table1.fieldByName('respuesta4').AsString; 5: RespuestaCAD := Table1.fieldByName('respuesta5').AsString; end; Table1.Close; begin ListBox1.Items.Add(EditPregunta.Text); ListBox1.Items.Add(RespuestaCAD); EditPregunta.Text :=''; end; end; end; end. Me aparece un problema y es que al introducir una frase o palabra, por ejemplo 'hola' a veces me contesta bien con una de las 5 respuestas posibles, pero a veces falla y no contesta nada. Lo tengo programado para que en el ListBox aparezca la frase del usuario y la respuesta, con lo cual cuando falla, solo aparece la frase del usuario y una línea en blanco. Podeís decirme que estoy haciendo mal.? Gracias. Manuel Reixach |
#16
|
||||
|
||||
existe un begin mal puesto...a parte el ramdom de 5 puede darte valor 0 y no lo tienes contemplado...mejor ponerlo a 4 ... el procedure quedaría asi.
|
#17
|
|||
|
|||
Hola Tony.
Gracias por tu ayuda. De todas formas, he modificado el procedure como tú me indicas y sigue pasando lo mismo, hay alguna frase que no me la contesta. Supongo que debe haber algo más que esta mal. Saludos Manuel |
#18
|
||||
|
||||
que raro, lo veo un poco imposible si haces un random de 4 solo puede salir 0,1,2,3,4 con lo que tienes acotada las posibilidades y RespuestaCAD siempre se rellena.... como no sea que en la tabla tengas alguna de las 5 respuestas vacia a alguna pregunta.....
|
#19
|
|||
|
|||
Hola otra vez Tony.
Parece ser que he encontrado el fallo. En la tabla he tenido que renombrar los campos de respuesta, que estaban de respuesta1 a respuesta5, y poner de respuesta0 a respuesta4. Y en el case, que estaba todo de 1 a 5, poner de 0 a 4. Ahora lo he probado varias veces y no ha fallado ninguna. Saludos. Manuel |
#20
|
||||
|
||||
Cita:
Saluditos
__________________
Disfruten cada minuto de su vida a lado de sus seres queridos como si fuese el ultimo, uno nunca sabe lo que puede pasar. |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
consulta a un query en vez de a una tabla | eldiegofg | SQL | 10 | 19-09-2007 12:46:39 |
Consulta Estado de una Tabla SQL | Alejandro73 | SQL | 2 | 24-06-2007 00:03:00 |
Crear tabla en una BD en Server A desde consulta en tabla B en server B | joaquinalberto | MySQL | 1 | 18-05-2007 10:39:27 |
Grabar Consulta en Tabla | don malo | Varios | 1 | 12-03-2007 23:45:59 |
Actualizar una tabla con una consulta de otra tabla | JODELSA | SQL | 2 | 14-09-2006 04:07:01 |
|