Foros del Web » Programando para Internet » PHP » Symfony »

[SOLUCIONADO] Doble duda (bases de datos y Symfony-Doctrine)

Estas en el tema de Doble duda (bases de datos y Symfony-Doctrine) en el foro de Symfony en Foros del Web. Buenas. Tengo una doble duda que pertenece tanto al apartado de bases de datos como a Symfony-Doctrine. Tengo una tabla de vehiculos definida así: Código: ...
  #1 (permalink)  
Antiguo 09/05/2016, 08:00
 
Fecha de Ingreso: marzo-2007
Mensajes: 59
Antigüedad: 17 años
Puntos: 0
Doble duda (bases de datos y Symfony-Doctrine)

Buenas.
Tengo una doble duda que pertenece tanto al apartado de bases de datos como a Symfony-Doctrine.

Tengo una tabla de vehiculos definida así:
Código:
CREATE TABLE `vehiculos` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `id_usuario` bigint(20) NOT NULL,
  `id_vehiculos_tipo` bigint(20) NOT NULL,
  `matricula` varchar(50) COLLATE utf8_unicode_ci NOT NULL,
  `seguro` varchar(200) COLLATE utf8_unicode_ci NOT NULL,
  `fecha_proxima_itv` date NOT NULL,
  `vehiculo_principal` tinyint(1) NOT NULL,
  PRIMARY KEY (`id`)
)
Y otra de vehiculos_tipos así:
Código:
CREATE TABLE `vehiculos_tipos` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `descripcion_vehiculo` varchar(100) COLLATE utf8_unicode_ci NOT NULL,
  PRIMARY KEY (`id`)
)
Las he definido mediante las entidades:
Vehiculos.php

Código PHP:
<?php

namespace AppBundleEntity
;

use 
DoctrineORMMapping as ORM;

/**
 * Vehiculos
 *
 * @ORM\Table()
 * @ORM\Entity(repositoryClass="AppBundle\Entity\VehiculosRepository")
 */
class Vehiculos
{
    
/**
     * @var integer
     *
     * @ORM\Column(name="id", type="bigint")
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    
private $id;

    
/**
     * @var integer
     *
     * @ORM\Column(name="id_usuario", type="bigint")
     */
    
private $idUsuario;

    
/**
     * @var integer
     *
     * @ORM\Column(name="id_vehiculos_tipo", type="bigint")
     */
    
private $idVehiculosTipo;

    
/**
     * @var string
     *
     * @ORM\Column(name="matricula", type="string", length=50)
     */
    
private $matricula;

    
/**
     * @var string
     *
     * @ORM\Column(name="seguro", type="string", length=200)
     */
    
private $seguro;

    
/**
     * @var \DateTime
     *
     * @ORM\Column(name="fecha_proxima_itv", type="date")
     */
    
private $fechaProximaItv;

    
/**
     * @var boolean
     *
     * @ORM\Column(name="vehiculo_principal", type="boolean")
     */
    
private $vehiculoPrincipal;


    
/**
     * Get id
     *
     * @return integer 
     */
    
public function getId()
    {
        return 
$this->id;
    }

    
/**
     * Set idUsuario
     *
     * @param integer $idUsuario
     * @return Vehiculos
     */
    
public function setIdUsuario($idUsuario)
    {
        
$this->idUsuario $idUsuario;

        return 
$this;
    }

    
/**
     * Get idUsuario
     *
     * @return integer 
     */
    
public function getIdUsuario()
    {
        return 
$this->idUsuario;
    }

    
/**
     * Set idVehiculosTipo
     *
     * @param integer $idVehiculosTipo
     * @return Vehiculos
     */
    
public function setIdVehiculosTipo($idVehiculosTipo)
    {
        
$this->idVehiculosTipo $idVehiculosTipo;

        return 
$this;
    }

    
/**
     * Get idVehiculosTipo
     *
     * @return integer 
     */
    
public function getIdVehiculosTipo()
    {
        return 
$this->idVehiculosTipo;
    }

    
/**
     * Set matricula
     *
     * @param string $matricula
     * @return Vehiculos
     */
    
public function setMatricula($matricula)
    {
        
$this->matricula $matricula;

        return 
$this;
    }

    
/**
     * Get matricula
     *
     * @return string 
     */
    
public function getMatricula()
    {
        return 
$this->matricula;
    }

    
/**
     * Set seguro
     *
     * @param string $seguro
     * @return Vehiculos
     */
    
public function setSeguro($seguro)
    {
        
$this->seguro $seguro;

        return 
$this;
    }

    
/**
     * Get seguro
     *
     * @return string 
     */
    
public function getSeguro()
    {
        return 
$this->seguro;
    }

    
/**
     * Set fechaProximaItv
     *
     * @param \DateTime $fechaProximaItv
     * @return Vehiculos
     */
    
public function setFechaProximaItv($fechaProximaItv)
    {
        
$this->fechaProximaItv $fechaProximaItv;

        return 
$this;
    }

    
/**
     * Get fechaProximaItv
     *
     * @return \DateTime 
     */
    
public function getFechaProximaItv()
    {
        return 
$this->fechaProximaItv;
    }

    
/**
     * Set vehiculoPrincipal
     *
     * @param boolean $vehiculoPrincipal
     * @return Vehiculos
     */
    
public function setVehiculoPrincipal($vehiculoPrincipal)
    {
        
$this->vehiculoPrincipal $vehiculoPrincipal;

        return 
$this;
    }

    
/**
     * Get vehiculoPrincipal
     *
     * @return boolean 
     */
    
public function getVehiculoPrincipal()
    {
        return 
$this->vehiculoPrincipal;
    }
}

Y VehiculosTipos.php:

Código PHP:
<?php

namespace AppBundleEntity
;

use 
DoctrineORMMapping as ORM;

/**
 * VehiculosTipos
 *
 * @ORM\Table()
 * @ORM\Entity(repositoryClass="IP\RestBundle\Entity\VehiculosTiposRepository")
 */
class VehiculosTipos
{
    
/**
     * @var integer
     *
     * @ORM\Column(name="id", type="bigint")
     * @ORM\Id
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    
private $id;

    
/**
     * @var string
     *
     * @ORM\Column(name="descripcion_vehiculo", type="string", length=100)
     */
    
private $descripcionVehiculo;


    
/**
     * Get id
     *
     * @return integer 
     */
    
public function getId()
    {
        return 
$this->id;
    }

    
/**
     * Set descripcionVehiculo
     *
     * @param string $descripcionVehiculo
     * @return VehiculosTipos
     */
    
public function setDescripcionVehiculo($descripcionVehiculo)
    {
        
$this->descripcionVehiculo $descripcionVehiculo;

        return 
$this;
    }

    
/**
     * Get descripcionVehiculo
     *
     * @return string 
     */
    
public function getDescripcionVehiculo()
    {
        return 
$this->descripcionVehiculo;
    }
}
Pues bien, la idea es que la tabla de vehículos contiene los vehículos de los usuarios de la base de datos y esta tabla tiene un campo "id_vehiculos_tipos" que se relaciona con el campo "id" de la tabla vehiculos_tipos. Es decir, por ejemplo, la tabla vehiculos_tipos puede tener:
id | descripcion_vehiculo
1 | Moto
2 | Coche
3 | Furgoneta

Y en la tabla vehiculos un usuario puede tener 2 vehículos, por ejemplo:
id | id_usuario | id_vehiculos_tipo | matricula | seguro | fecha_proxima_itv | vehiculo_principal
1 | 23 | 1 | 1234abc | ... | ... | 1
2 | 23 | 3 | 6789xyz | ... | ... | 0

Pues bien, dicho todo esto mi primera duda surge en algo que no tengo mucha experiencia.
1. Las relaciones entre estas tablas ¿de qué tipo son? Si no me equivoco sería de uno a muchos desde la tabla vehiculos_tipos a la tabla vehiculos ¿Correcto?

Y la segunda duda.
2. En tal caso, ¿cómo se define esto en Symfony?

Muchas gracias por la ayuda.
Un saludo.
  #2 (permalink)  
Antiguo 09/05/2016, 15:26
Avatar de hhs
hhs
Colaborador
 
Fecha de Ingreso: junio-2013
Ubicación: México
Mensajes: 2.995
Antigüedad: 10 años, 9 meses
Puntos: 379
Respuesta: Doble duda (bases de datos y Symfony-Doctrine)

La relación sera muchos a uno, y te aconsejo que leas la documentación, en esta sección del manual puedes ver todas las relaciones que puedes crear con Doctrine: http://docs.doctrine-project.org/pro...ociations.html
__________________
Saludos
About me
Laraveles
A class should have only one reason to change.
  #3 (permalink)  
Antiguo 10/05/2016, 00:54
 
Fecha de Ingreso: marzo-2007
Mensajes: 59
Antigüedad: 17 años
Puntos: 0
Respuesta: Doble duda (bases de datos y Symfony-Doctrine)

Ok hhs me miraré la documentación.
Muchas gracias por la respuesta.

Un saludo
:)

Etiquetas: bases, doble
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 21:09.