Neodatis 和口是心非

Neodatis and duplicities

Neodatis 创建一个新的 "Pais" 当有一个相同的。

我在 GUI 上使用 Neodatis。我有一个包含 "Jugadores" 和 "Pais." 的数据库 "Jugadores" 具有 "Pais" 的属性。当我想用现有 "Pais" 之一向数据库添加新的 "Jugadores" 时,在数据库中重新创建它,因为查询 return 没有同名的数据库.

GUI 代码:

gestionLiga gestionLiga = new gestionLiga();

gestionLiga.altaJugador(txtNombre.getText(), txtDeporte.getText(), txtCiudad.getText(), Integer.parseInt(txtEdad.getText()), gestionLiga.sacarPais(txtPais.getText()));

gestionLiga.sacarPais代码:

public Pais sacarPais(String pais)
    {
    odb = ODBFactory.open("EQUIPOS.test");
    IQuery query = new CriteriaQuery(Pais.class, Where.equal("nombre",pais));   
    Objects <Pais> listado = odb.getObjects(query);
    if(listado.size() == 0)
    {
        int contador;
        IQuery query2 = new CriteriaQuery(Pais.class);
        Objects <Pais> listado2 = odb.getObjects(query2);
        contador = listado2.size()+1;
        odb.close();
        return new Pais(contador, pais);
    }
    else
    {
        odb.close();
        return (Pais)listado.getFirst();
    }
}

gestionLiga.altaJugador代码:

public void altaJugador(String nombre, String deporte, String ciudad, int edad, Pais pais)
{
    odb = ODBFactory.open("EQUIPOS.test");
    Jugadores jugador = new Jugadores(nombre, deporte, ciudad, edad, pais);
    odb.store(jugador);
    odb.close();
}

派class码:

class Pais 
{
 private int id;
 private String nombre;

public Pais(){}

public Pais(int id, String nombre) {
    this.id = id;
    this.nombre = nombre;
}

public int getId() {
    return id;
}

public void setId(int id) {
    this.id = id;
}

public String getNombre() {
    return nombre;
}

public void setNombre(String nombre) {
    this.nombre = nombre;
}

public String toString()
{
    return this.nombre;
}
}

Jugadores class代码:

public class Jugadores 
{

private String nombre, deporte, ciudad;
private int edad;
private Pais pais;
public Jugadores(){} 

public Jugadores(String nombre, String deporte, String ciudad, int edad, Pais pais) 
{
    this.nombre = nombre;
    this.deporte = deporte;
    this.ciudad = ciudad;
    this.edad = edad;
    this.pais = pais;
}

public String getNombre() 
{
    return nombre;
}

public void setNombre(String nombre) 
{
    this.nombre = nombre;
}

public String getDeporte() 
{
    return deporte;
}

public void setDeporte(String deporte) 
{
    this.deporte = deporte;
}

public String getCiudad() 
{
    return ciudad;
}

public void setCiudad(String ciudad) 
{
    this.ciudad = ciudad;
}

public int getEdad() 
{
    return edad;
}

public void setEdad(int edad) 
{
    this.edad = edad;
}

public Pais getPais() {
    return pais;
}

public void setPais(Pais pais) {
    this.pais = pais;
}

@Override
public String toString() {
    return "NOMBRE: " + nombre + " - DEPORTE: " + deporte + " - CIUDAD: " + ciudad + " - EDAD: " + edad + " - PAIS: " + pais;
}


}

如果我输入同一个国家的两个玩家,理论上的查询应该 return 我已经有一个同名的 Pais,不应该创建一个新的,但是,输入 IF 和创建一个新的。

感谢您的帮助!

我只是不关闭 sacarPais 上的 odb,然后我不打开(因为我无法打开它两次)altaJugador。在插入带有 Pais 参考的新 Jugador 后,我关闭了 odb。大功告成,一坨屎。