Class GetPilotOnline
java.lang.Object
org.deltava.dao.DAO
org.deltava.dao.PilotReadDAO
org.deltava.dao.GetPilotOnline
A Data Access Object to load Pilot data for Online Network operations.
- Since:
- 1.0
- Version:
- 10.3
- Author:
- Luke
-
Field Summary
Fields inherited from class PilotReadDAO
_cacheFields inherited from class DAO
_queryMax, _queryStart, _queryTimeout, WGS84_SRIDModifier and TypeFieldDescriptionprotected intThe maximum number of rows to return.protected intThe row number at which to start returning results.protected intThe query timeout, in seconds.protected static final intThe SRID used for geolocation queries. -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptiongetIDs(OnlineNetwork network) Returns the network IDs for all Active/On leave pilots.getPilots(OnlineNetwork network) Returns all Pilots registered with an ID in a particular online network.Methods inherited from class PilotReadDAO
execute, get, get, get, getByID, getByName, loadAccomplishments, loadChildRows, loadIMAddrs, loadPushEndpoints, loadRatings, loadRoles, updatePilotCodesModifier and TypeMethodDescriptionQuery pilot objects from the database, assuming a pre-prepared statement.final Pilotget(int id) Gets a pilot object based on a database ID.Returns a Pilot object which may be in another Airline's database.get(UserDataMap udm) Returns Pilot objects which may be in another Airline's database.getByID(Collection<?> ids, String tableName) Returns a Map of pilots based on a Set of pilot IDs.Returns a Pilot based on a given full name.protected final voidloadAccomplishments(Map<Integer, Pilot> pilots, String dbName) Load the accomplishment IDs for a group of Pilots.protected final voidloadChildRows(Pilot p, String dbName) Load the ratings, roles and accomplishment IDs for a Pilot.protected final voidloadIMAddrs(Map<Integer, Pilot> pilots, String dbName) Load social media addresses for a group of Pilots.protected final voidloadPushEndpoints(Map<Integer, Pilot> pilots, String dbName) Loads push notification endpoints for a group of Pilots.protected final voidloadRatings(Map<Integer, Pilot> pilots, String dbName) Load the equipment ratings for a group of Pilots.protected final voidLoad the security roles for a group of Pilots.protected static final voidupdatePilotCodes(Collection<Pilot> pilots, String dbName) Updates the Pilot codes when loading Pilots from different databases.Methods inherited from class DAO
commitTransaction, createTimestamp, executeIDs, executeUpdate, executeUpdate, expandDate, formatDBName, formatLocation, getNewID, getQueryCount, prepare, prepareWithoutLimits, rollbackTransaction, setQueryMax, setQueryStart, setQueryTimeout, startTransaction, toID, toID, toInstantModifier and TypeMethodDescriptionprotected voidCommits a multi-step transaction to the database.protected static TimestampNull-safe conversion of an Instant to a Timestamp.Helper method to extract database ID data from the result set.protected static intexecuteUpdate(PreparedStatement ps, int minUpdateCount) Executes an UPDATE transaction on a prepared statement, and throws aSQLExceptionif less than the expected number of rows were updated.protected static intexecuteUpdate(PreparedStatement ps, int minPerUpdate, int minTotal) Executes an batched UPDATE transaction on a prepared statement, and throws aSQLExceptionif less than the expected number of rows were updated per batch entry.protected static InstantexpandDate(Date dt) Converts a date-only JDBC value into a full timestamp.protected static StringformatDBName(String db) Formats a database name by converting to lowercase.protected static StringConverts a geographic location into a MySQL WKT formatted point.protected intgetNewID()Returns the AUTO_INC column value generated by the previous JDBC transaction.static final longReturns the total number of queries executed since the JVM was started.protected PreparedStatementInitialize the prepared statement with an arbitrary SQL statement.protected PreparedStatementInitialize the prepared statement with an abitrary SQL statement, without applying the DAO's query result limitations.protected voidRolls back a multi-step transaction before it is completed.final voidsetQueryMax(int maxRows) Sets the maximum number of rows in the returned result set.final voidsetQueryStart(int rowStart) Sets the first row of the results to return.voidsetQueryTimeout(int timeout) Sets the timeout for any SQL operations.protected voidMarks the start of a multi-step database transaction.protected static IntegerConverts a Database bean or an Integer into an Integer.protected static Collection<Integer> toID(Collection<?> ids) Converts a collection of Objects into Integer IDs.protected static InstantNull-safe conversion of a Timestamp to an Instant.
-
Constructor Details
-
GetPilotOnline
Initializes the Data Access Object.- Parameters:
c- the JDBC connection to use
-
-
Method Details
-
getIDs
Returns the network IDs for all Active/On leave pilots. This will return a Map with the network ID as the key, and the database ID of the Pilot as the value, allowing easy lookups of Pilots based on network ID.- Parameters:
network- the network- Returns:
- a Map of network ID/database ID pairs
- Throws:
DAOException- if a JDBC error occurs
-
getPilots
Returns all Pilots registered with an ID in a particular online network. Flight Totals will not be populated.- Parameters:
network- the online network- Returns:
- a List of Pilots
- Throws:
DAOException- if a JDBC error occurs
-