elhacker.net cabecera Bienvenido(a), Visitante. Por favor Ingresar o Registrarse
¿Perdiste tu email de activación?.

 

 


Tema destacado: Arreglado, de nuevo, el registro del warzone (wargame) de EHN


  Mostrar Mensajes
Páginas: 1 ... 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 [20] 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 ... 88
191  Programación / Programación C/C++ / Re: Arreglos de cadenas en C en: 2 Junio 2020, 01:53 am
Una cadena con espacios tiene la misma representación que una sin espacios ya que un espacio también es un char.
La cadena la puedes reservar de forma estática:
Código
  1. #define SIZE 50
  2. char cadena[50];
O de forma dinámica:
Código
  1. #define SIZE 50
  2. char *cadena = (char*)malloc(SIZE * sizeof(char));
Recuerda que si lo haces de forma dinámica, luego tienes que liberar la memoria reservada:
Código
  1. free(cadena);

Para poder guardar espacios lo importante es usar la función fgets() en vez de scanf().
Código
  1. fgets(cadena, SIZE, stdin);
Esto guardará el ENTER que pulses al final como parte de la cadena (siempre que no hayas llegado a los SIZE-1 caracteres, ya que el último se reserva para el carácter de fin de cadena '\0'). Para eliminar el salto de línea producido por el ENTER:
Código
  1. if(cadena[strlen(cadena)-1] == '\n')
  2.  cadena[strlen(cadena)-1] = '\0';
192  Programación / Bases de Datos / Re: Pasar modelo entidad relacion a MySQL en: 1 Junio 2020, 20:25 pm
Claro, no me había dado cuenta.
Si al crear una tabla (Pedido), intentas hacer referencia a otras tablas (Vendedor y Cliente), estas tienen que existir ya.
Por eso si creas FKs tienes que asegurarte que primero creas las tablas a las que vas a hacer referencia.
193  Programación / Bases de Datos / Re: Pasar modelo entidad relacion a MySQL en: 1 Junio 2020, 20:03 pm
Diría que el problema que tienes se debe a que tienes que especificar el tamaño máximo de cada varchar.
Es decir varchar(n) donde n es un número. Si no quieres especificar un tamaño puedes usar MAX pero no es muy recomendable generalmente.

Si tienes algún problema más, incluye también el mensaje de error que te salga.
194  Programación / Bases de Datos / Re: Pasar modelo entidad relacion a MySQL en: 1 Junio 2020, 12:03 pm
Hola de nuevo releyendo me he encontrado con esto: El campo BANCO es un string que representa el nombre del BANCO. (los datos concretos de pago como numero de cuenta se encuentran alojados en otra tabla a la cual se accede a través del número de control)
Lo que me raya la cabeza es el contenido del paréntesis, que significa, por más que intento comprender no entiendo lo que se pide.
Lo que te está pidiendo de forma indirecta es que tengas otra tabla con los datos concretos del pago, llamémosla InfoPago. Esta tabla tendrá como te dicen pues el número de cuenta y podría tener otras cosas como el titular o lo que consideres/te indiquen.
Y que la relación entre InfoPago - Pago será 1:N. Cada pago apunta a un único registro de InfoPago mientras que cada registro de InfoPago puede ser referido desde diferentes pagos.

El uso de esto es para no copiar todos los datos en cada pago. Guardas en una tabla el número de cuenta, titular,... y le das un número de control. Así cuando quieras decir que un pago fue realizado por un número de cuenta, en vez de copiar todo (número de cuenta, titular,...) solo tendrás que copiar el número de control y eso te permitirá saber siempre qué número de cuenta, titular,... hizo ese pago.

Por si acaso diré que numeroControl tiene toda la pinta de ser la PK de InfoPago y una FK de Pago hacia InfoPago.
195  Programación / Programación C/C++ / Re: Agenda telefonica en: 1 Junio 2020, 11:47 am
Visto que todas mis recomendaciones anteriores fueron ignoradas, me limitaré a decirte el procedimiento que tienes que seguir:
Código:
PEDIR telefono
indice := 0
MIENTRAS indice < contactosTotales && telefono != contactos[indice].telefono HACER
  indice := indice + 1
FIN MIENTRAS
// Si indice = contactosTotales, el numero buscado no existe
SI telefono = contactos[indice].telefono ENTONCES
  PEDIR nuevoTelefono
  contactos[indice].telefono = nuevoTelefono
FIN SI
Ahora tienes que adaptar este psedocódigo a tu problema mirando a ver cómo puedes representar las variables que aparecen.
Suerte. :-X
196  Programación / Bases de Datos / Re: Pasar modelo entidad relacion a MySQL en: 1 Junio 2020, 00:34 am
No sería necesario guardarlo al revés creo yo, solo necesito lo que puse en la primera entrada(no estoy seguro xdd)
Pues entonces con tener la relación hecha en el otro sentido ya vale. Además la importante es la que te permite borrar el pago automáticamente cuando borras el pedido relacionado. Así que ya sabes: esa no hace falta y la otra la estabas poniendo al revés. Ahora te toca hacerlo en MySQL.
197  Programación / Bases de Datos / Re: Pasar modelo entidad relacion a MySQL en: 31 Mayo 2020, 20:58 pm
Las claves foráneas quedarían así Id_vendedor en pedido, id_pedido en cliente, id_pago en pedido?
No tengo muy claro como crear la estructura con estas claves
Mira a ver si tal y como tú dices se cumplen las normas que te puse antes sobre cómo establecer las relaciones.
Ya te adelanto que la segunda no lo cumple.
Y la tercera ya te lo puse yo con la clave de id_pedido en Pago, no sé si de verdad necesitas guardarlo al revés también.
198  Programación / Programación C/C++ / Re: Process returned -1073741819 en: 31 Mayo 2020, 16:13 pm
Otras cosa que veo es en la línea 241, con ese n-1 estás dejando la última posición sin "limpiar".
Seguramente tengas algún problema en la llamada recursiva de tipus3d() (línea 407).

Lo mejor que puedes hacer es usar algún depurador o hacerlo a la vieja ausanza con unos printf() por ahí para ver cómo van cambiando las variables.
199  Programación / Programación C/C++ / Re: Process returned -1073741819 en: 31 Mayo 2020, 15:47 pm
Lo que veo a simple vista es que el array vmin tiene una longitud de n que no sé cuánto será puesto que depende del fichero pero en la función tipus3d() le asignas 100 veces el valor 0 a vmin[100].

Mira a ver si corrigiendo eso, el error se arregla. No he mirado mucho más puesto que el código es muy grande y hay que decir que la identación no ayuda mucho a identificar los bloques de código. :rolleyes:

Suerte. :-X

PD: Para pasar un puntero a una función, en vez de usar &(*p), puedes usar directamente p. Los operadores & y * se anulan al final.
200  Programación / Bases de Datos / Re: Pasar modelo entidad relacion a MySQL en: 31 Mayo 2020, 11:23 am
Entre las demás tablas y relaciones, habría que crearlas normal o como has hecho tú?
No sé a qué te refieres con crearlas normal o como las he hecho yo...

Si te refieres a lo de crear una nueva tabla para la relación, eso es necesario únicamente para las relaciones con cardinalidad N:M. Digamos que la regla general es:
  • Cardinalidad N:M -> Nueva tabla formada por las PKs de las dos tablas [+ discriminantes] como PK de la nueva, otros atributos de la relación y FKs de cada PK original a su tabla de origen.
  • Cardinalidad 1:N -> La tabla con cardinalidad N contiene una FK a la PK de la tabla con cardinalidad 1.
  • Cardinalidad 1:1 -> Una tabla contiene la FK a la PK de la otra. Cuál? Depende del problema muchas veces. La que más información aporte.

Si te refieres al ON DELETE CASCADE, pues dependerá de lo que quieras eliminar en cascada o no.
Páginas: 1 ... 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 [20] 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 ... 88
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines