Add method to get all artists for a group.
authorDavid ‘Bombe’ Roden <bombe@pterodactylus.net>
Thu, 19 Apr 2012 14:29:24 +0000 (16:29 +0200)
committerDavid ‘Bombe’ Roden <bombe@pterodactylus.net>
Thu, 19 Apr 2012 14:29:24 +0000 (16:29 +0200)
src/main/java/net/pterodactylus/demoscenemusic/data/DataManager.java

index 5554f76..b56634f 100644 (file)
@@ -76,6 +76,14 @@ public class DataManager {
                return artistLoader.get();
        }
 
+       public Collection<Artist> getArtistsByGroup(String groupId) throws DatabaseException {
+               Query query = new Query(Type.SELECT, "ARTISTS");
+               query.addField(new Field("ARTISTS.*"));
+               query.addJoin(new Join(JoinType.INNER, "GROUP_ARTISTS", new Field("ARTISTS.ID"), new Field("GROUP_ARTISTS.ARTIST")));
+               query.addWhereClause(new ValueFieldWhereClause(new ValueField("GROUP_ARTISTS.GROUP_", new StringParameter(groupId))));
+               return database.getMultiple(query, artistCreator);
+       }
+
        public Track trackById(String id) throws DatabaseException {
                Query query = new Query(Type.SELECT, "TRACKS");
                query.addField(new Field("TRACKS.*"));