import java.util.Collection;
import java.util.HashSet;
import java.util.List;
+import java.util.concurrent.Callable;
+import net.pterodactylus.util.collection.Memoizer;
import net.pterodactylus.util.database.Database;
import net.pterodactylus.util.database.DatabaseException;
import net.pterodactylus.util.database.Field;
return artistLoader.all();
}
+ public Artist getArtistById(String id) throws DatabaseException {
+ Query query = new Query(Type.SELECT, "ARTISTS");
+ query.addField(new Field("ARTISTS.*"));
+ query.addField(new Field("GROUP_ARTISTS.*"));
+ query.addField(new Field("GROUPS.*"));
+ query.addJoin(new Join(JoinType.INNER, "GROUP_ARTISTS", new Field("ARTISTS.ID"), new Field("GROUP_ARTISTS.ARTIST")));
+ query.addJoin(new Join(JoinType.INNER, "GROUPS", new Field("GROUP_ARTISTS.GROUP_"), new Field("GROUPS.ID")));
+ query.addWhereClause(new ValueFieldWhereClause(new ValueField("ARTISTS.ID", new StringParameter(id))));
+ query.addOrderField(new OrderField(new Field("ARTISTS.ID")));
+ ArtistLoader artistLoader = new ArtistLoader();
+ database.process(query, artistLoader);
+ return artistLoader.get();
+ }
+
public Track trackById(String id) throws DatabaseException {
Query query = new Query(Type.SELECT, "TRACKS");
query.addField(new Field("TRACKS.*"));
return trackLoader.get();
}
+ public Collection<Track> getTracksByArtist(String artistId) throws DatabaseException {
+ Query query = new Query(Type.SELECT, "TRACKS");
+ query.addField(new Field("TRACKS.*"));
+ query.addField(new Field("TRACK_ARTISTS.*"));
+ query.addField(new Field("ARTISTS.*"));
+ query.addField(new Field("TRACK_STYLES.*"));
+ query.addField(new Field("STYLES.*"));
+ query.addJoin(new Join(JoinType.INNER, "TRACK_ARTISTS", new Field("TRACKS.ID"), new Field("TRACK_ARTISTS.TRACK")));
+ query.addJoin(new Join(JoinType.INNER, "ARTISTS", new Field("TRACK_ARTISTS.ARTIST"), new Field("ARTISTS.ID")));
+ query.addJoin(new Join(JoinType.INNER, "TRACK_STYLES", new Field("TRACKS.ID"), new Field("TRACK_STYLES.TRACK")));
+ query.addJoin(new Join(JoinType.INNER, "STYLES", new Field("TRACK_STYLES.STYLE"), new Field("STYLES.ID")));
+ query.addWhereClause(new ValueFieldWhereClause(new ValueField("ARTISTS.ID", new StringParameter(artistId))));
+ query.addOrderField(new OrderField(new Field("TRACKS.ID"), Order.ASCENDING));
+ query.addOrderField(new OrderField(new Field("TRACK_ARTISTS.DISPLAY_ORDER"), Order.ASCENDING));
+ TrackLoader trackLoader = new TrackLoader();
+ database.process(query, trackLoader);
+ return trackLoader.all();
+ }
+
private class TrackLoader implements ResultProcessor {
private final List<Track> loadedTracks = new ArrayList<Track>();
private Track track;
+ public Track get() {
+ return loadedTracks.isEmpty() ? null : loadedTracks.get(0);
+ }
+
+ public List<Track> all() {
+ return loadedTracks;
+ }
+
/**
* {@inheritDoc}
*/
track.styles().add(style);
}
- public Track get() {
- return loadedTracks.isEmpty() ? null : loadedTracks.get(0);
- }
-
}
private class ArtistLoader implements ResultProcessor {
private final List<Artist> artists = new ArrayList<Artist>();
private Artist artist;
+ public Artist get() {
+ return artists.isEmpty() ? null : artists.get(0);
+ }
+
public List<Artist> all() {
return artists;
}
}
+ private class LazyArtist extends DefaultArtist {
+
+ private final Memoizer<Void> tracks = new Memoizer<Void>(new Callable<Void>() {
+ public Void call() throws DatabaseException {
+ if (!hasValue("tracks")) {
+ value("tracks", Collection.class).set(getTracksByArtist(id()));
+ }
+ return null;
+ }
+ });
+
+ public LazyArtist(String id) {
+ super(id);
+ }
+
+ public Collection<Track> tracks() {
+ tracks.get();
+ return value("tracks", Collection.class).get();
+ }
+
+ }
+
}