*/ class TextProcessingProviderQueueMapper extends QBMapper { public function __construct(IDBConnection $db) { parent::__construct($db, 'ex_text_processing_q'); } /** * @param int $id * * @throws DoesNotExistException if not found * @throws MultipleObjectsReturnedException if more than one result * @throws Exception * * @return TextProcessingProviderQueue */ public function getById(int $id): TextProcessingProviderQueue { $qb = $this->db->getQueryBuilder(); $qb->select('*') ->from($this->tableName) ->where( $qb->expr()->eq('id', $qb->createNamedParameter($id)) ); return $this->findEntity($qb); } /** * @throws Exception */ public function removeAllOlderThenThat(int $overdueTime): int { $qb = $this->db->getQueryBuilder(); $qb->delete($this->tableName) ->where( $qb->expr()->gte($qb->createNamedParameter(time() - $overdueTime, IQueryBuilder::PARAM_INT), 'created_time') ); return $qb->executeStatement(); } }