FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
Como organizar un cliente con varios contactos
Buenas tardes,
estoy haciendo un programa de gestión de prestamos y me surge una duda a la hora de organizar las tablas. El caso es que tengo una tabla de clientes donde quiero reflejar los datos básicos pero necesito poder indicar una serie de "contactos" que están relacionados con el. Por ejemplo al dar de alta un cliente a veces es necesario indicar el nombre de su cónyuge, de sus hermanos, hijos... Para estos contactos no querría tener que crear otra tabla sino más bien usar la misma de clientes pero que de alguna forma se sepa que están relacionados entre ellos. No sería válido poner campos auxiliares ya que es un número no determinado de personas, en algunos casos hay uno y otros puede haber 4 o 5. Así al entrar en un cliente vería quienes más están vinculados a él y podría acceder a sus datos. No se si me he explicado bien. ¿Alguien podría decirme cómo puedo plantear esto para tener una idea de cómo se suele hacer? Ando un poco perdido y dándole vueltas pero quizás sea algo habitual. Muchas Gracias
__________________
Mi proyecto paso a paso (Parte I) |
#2
|
||||
|
||||
Estimado Delphitest:
En mi experiencia lo mejor es crear otra tabla (Contactos) y unirlas a través de un campo común en una relación maestro-detalle. Saludos |
#3
|
||||
|
||||
Puedes tener un dato "tipo de usuario"
0. cliente 1. proveedor 2. cónyuge 3. hijo 4. amigo 5. vecino ... Y para más funcionalidad, una tabla para definirlos y así poder ampliarlos, editarlos, etc. |
#4
|
|||
|
|||
Muchas gracias por vuestras opiniones,
en este ultimo caso Casimiro, es algo que había pensado Por ejemplo pongo "Tipo de Cliente" ; Cliente Principal Hermano Padre Hijo .... ¿Pero como lo vinculo al cliente principal? ¿Creo otro campo tipo "Relacionado con.."? ¿O como podría hacerlo? Es decir, hay un cliente principal y luego puede estar el padre, el hermano... pero sería necesario saber que están relacionados. Lo de crear otra tabla de contactos sería otra opción, por eso ando preguntando, no lo tengo muy claro cual sería la mejor forma.
__________________
Mi proyecto paso a paso (Parte I) |
#5
|
||||
|
||||
Necesitas otra tabla.
Código:
cliente.....otra cosa 1------------34 1------------14 1------------3 2------------48 2------------1 3------------15 3------------5 3------------4 |
#6
|
|||
|
|||
Voy a probar con lo que comentáis de crear otra tabla de contactos.
No se exactamente como funcionan las relaciones pero por lógica entiendo que debo de tener un campo común en las dos tablas que me permita relacionarlas. Tengo la tabla "clientes" con estos campos: IDCliente Nombre Apellidos .... Y debo crear la tabla "contactos" con estos: IDContacto Nombre Apellidos ... Supongo que esta última tengo que poner un campo IDCliente para que en caso de que haya varios contactos de un mismo cliente se sepa con quien están relacionados. Para relacionarlas ¿Basta con tener un campo común y crear una query a la hora de mostrarlos? Por ejemplo diciéndole que solo se vean los contactos que tengan el IDCLiente (de contactos) igual al IDCLiente (de Clientes) ¿O es necesario crear esa relación de forma especifica con alguna sentencia SQL?
__________________
Mi proyecto paso a paso (Parte I) |
#7
|
||||
|
||||
Depende de lo que vayas a hacer exactamente, pero si un cliente puede tener varios contactos y un contacto puede pertenecer a varios clientes, entonces creo que tendrás que usar una tabla intermedia que haga de unión entre ambos, como especifiqué antes.
|
#8
|
|||
|
|||
Solo necesitaría que un cliente pueda tener varios contactos pero los contactos serían únicos para el clientes, es decir bastaría saber de la ficha del contacto con qué cliente está relacionado, pero no tendría más de uno.
__________________
Mi proyecto paso a paso (Parte I) |
#9
|
||||
|
||||
Si un contacto solamente va a tener un enlace con un cliente entonces puedes añadir únicamente un campo en el contacto donde almacenas el código del cliente al que está enlazado.
Ejemplo: Código:
tbClientes id nombre telefono primary key (id) tbContactos id idCliente /* (id en tbClientes) */ nombre telefono primary key (id,idCliente) Mejor la primera forma, tabla intermedia. |
#10
|
|||
|
|||
Perfecto, ya me he puesto manos a la obra.
En mi caso un contacto nunca podrá ser de varios clientes asi que esto simplifica la tarea... Ya hice la tabla de Contactos con el campo IdCliente Lo que hago al añadir un Contacto desde la Ficha del Cliente es que automaticamente el IdCliente del contacto sea el valor de IdCliente de la tabla Cliente, lo hago incluyendo esta línea en el evento onclick del botón añadir:
La tabla contactos está en el Form actual pero la de clientes está en un Data Module. Hasta ahí creo que lo hago bien porque he probado y todo es correcto. En la finca de cliente he puesto un DBGrid donde pretendo que aparezcan todos los contactos relacionados con este cliente. Lo hago a través de una Query pero no sé qué debo poner el la sentencia SQL, ando un poco perdido con estas cosas. Si le pongo esto:
Vería todos los contacto, pero para ver únicamente los contactos cuyo IdCliente sea el mismo que el IdCLiente de la tabla Clientes no se que tengo que poner. Se hace con un where creo que al tener dos tablas no se como indicar que un campo sea igual al de otra tabla He probado con
Pero no funciona, debo de andar cerca.... También he visto una opción para poner un filtro en la query aunque no se si es ahí donde hay que ponerlo o en la SQL
__________________
Mi proyecto paso a paso (Parte I) |
#11
|
||||
|
||||
Hola Delphitest.
La consulta sería similar a esta: Pero desconozco los campos que deseas obtener y los componentes que estas usando como para darte una respuesta mas concreta. Saludos
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#12
|
||||
|
||||
Hola de nuevo.
Otra forma mas simple, pero una pizca menos eficiente es:
Saludos
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#13
|
|||
|
|||
En cuanto a los campos de la tabla contactos solo necesito Nombre, DNI y Telefono
El componente que uso es ADO La duda que tengo es cómo indicar la tabla clientes en la SQL ya que no está en el Form donde tengo la consulta de Contactos, está en Data Module que llamo DMMain
__________________
Mi proyecto paso a paso (Parte I) |
#14
|
||||
|
||||
Hola Delphitest.
(*) Donde "tu_variable" es cualquier variable (o constante) de tipo Integer que contenga el ID del cliente cuyos contactos se desea listar. Saludos
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#15
|
|||
|
|||
Buenos días,
gracias por vuestra ayuda, siento no haber contestado pero no acabo de conseguir hacerlo funcionar. Qué duro es esto de la programación por momentos... , me está dando la noche este problema El caso es que no se donde meter ese código que me comenta ecfisa y estoy intentando hacer una sola línea de sql para ponerla en las propiedades de la query TContactos pero sigo fallando en la parte que indica el campo IDCliente de la tabla TClientes y que no está en el mismo form, no se si me falta algo por probar pero he hecho todo tipo de combinaciones. Quizás la solución sea crear una variable en el Form que recoja el contenido de IDCLiente de la tabla TClientes y después hacer referencia a esa variable dentro de la sentencia SQL, pero mis pruebas tampoco han sido exitosas. No pierdo la esperanza, sigo haciendo pruebas...
__________________
Mi proyecto paso a paso (Parte I) |
#16
|
||||
|
||||
Por ejemplo, al pulsar un botón.
|
#17
|
|||
|
|||
Es que me estoy liando con esto...
Pensaba que la forma de hacerlo era poner en las propiedades SQL de la query lo necesario para que actuara de filtro y mostrase los datos que necesito. Voy a hacer mas pruebas poniendo en ese sitio "select * from contactos" porque requiere que ponga algo por lo que he comprobado y el código que proporciona ecfisa en algún botón aunque sea para ver si da el resultado esperado. Muchas gracias, os mantengo informados Que paséis un buen día.
__________________
Mi proyecto paso a paso (Parte I) |
#18
|
|||
|
|||
Solucionado con el código de ecfisa y una ayudita de un forero
He metido el código en el evento OnChange de las pestañas donde aparece el DBGrid con los datos de los contactos Gracias por todo
__________________
Mi proyecto paso a paso (Parte I) |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Compartir Contactos en Outlook | ChristianS | Windows | 4 | 15-12-2011 00:57:18 |
Importar contactos Outlook | Manuel1790 | Windows | 2 | 21-09-2007 17:15:08 |
actualizar aplicacion cliente en varios puesto | VRO | Providers | 0 | 25-10-2005 18:00:49 |
Exportar Contactos. messenger y ot | JXJ | Varios | 0 | 02-05-2005 02:25:11 |
Imprimir Contactos en Outlook | ChristianS | Windows | 0 | 02-09-2003 22:00:48 |
|