开发者

Accessing an custom class from a JDO Class

开发者 https://www.devze.com 2022-12-16 21:46 出处:网络
Right, I don\'t know if I\'m barking entirely up the wrong tree here - I\'m finding JDO and开发者_StackOverflow社区 the Google AppEngine a bit tricky to get the hang of. Anyway, here goes.

Right, I don't know if I'm barking entirely up the wrong tree here - I'm finding JDO and开发者_StackOverflow社区 the Google AppEngine a bit tricky to get the hang of. Anyway, here goes.

I have a class that contains another class as one of it's internal variables (see player1)

  @PersistenceCapable(identityType = IdentityType.APPLICATION)
   public class JDOGame 
   {    
    @PrimaryKey 
    @Persistent(valueStrategy = IdGeneratorStrategy.IDENTITY) 
    private Long id; 

    @Persistent
    private String map; 

    @Persistent
    private RPCDataPlayer player1;

   // getters, setters, constructors etc...
   }

The class RPCDataPlayer is Serializable and very basic....

public class RPCDataPlayer implements IsSerializable 
{
    public String name;
    public int id;

        // getters & setters & constructors oh my

        public int getId() { return id; }
}

So, my question is...how do I create a query where I can get all the JDOGames that contain an RPCDataPlayer with id = x?

I can't do a query like...

SELECT FROM JDOGame.class.getName() WHERE player1.getId() == x

...so what techniques or suggestions do people have for this to work?

Thanks in advance.


The Google App Engine Database is not a relational database so you can not do joins. You can persist RPCDataPlayer as a table.

@PersistenceCapable(identityType = IdentityType.APPLICATION)
public class RPCDataPlayer {

    @PrimaryKey
    @Persistent(valueStrategy = IdGeneratorStrategy.IDENTITY)
    private Key key;

    @Persistent(mappedBy = "player1")
    private List<JDOGame> jdoGames = new ArrayList<JDOGame>();

    @Persistent
    public String name;

    @Persistent
    public int id;

    public int getId() {
        return id;
    }

    public Key getKey() {
        return key;
    }

    public void setJdoGames(List<JDOGame> jdoGames) {
        this.jdoGames = jdoGames;
    }

    public List<JDOGame> getJdoGames() {
        return jdoGames;
    }

}

And then you can just query this like this.

SELECT FROM RPCDataPlayer.class.getName() WHERE id == x

Once you have and instance of RPCDataPlayer you can get get JDOGame by calling:

List<JDOGame> jdoGames = rpcDataPlayer.getJdoGames();


Your field is serialised in the datastore, so you obviously can't do a query in the datastore, hence all of those records need retrieving and the query doing in-memory. When GAE/J finally get their act together and allow people to do that then it will be trivial, until then you need to retrieve all records yourself and do the check.

Nothing to do with joins at all

0

精彩评论

暂无评论...
验证码 换一张
取 消