in core/src/main/scala/org/apache/pekko/persistence/r2dbc/snapshot/SnapshotDao.scala [119:142]
private def selectSql(criteria: SnapshotSelectionCriteria): String = {
val maxSeqNrCondition =
if (criteria.maxSequenceNr != Long.MaxValue) " AND seq_nr <= ?"
else ""
val minSeqNrCondition =
if (criteria.minSequenceNr > 0L) " AND seq_nr >= ?"
else ""
val maxTimestampCondition =
if (criteria.maxTimestamp != Long.MaxValue) " AND write_timestamp <= ?"
else ""
val minTimestampCondition =
if (criteria.minTimestamp != 0L) " AND write_timestamp >= ?"
else ""
sql"""
SELECT persistence_id, seq_nr, write_timestamp, snapshot, ser_id, ser_manifest, meta_payload, meta_ser_id, meta_ser_manifest
FROM $snapshotTable
WHERE persistence_id = ?
$maxSeqNrCondition $minSeqNrCondition $maxTimestampCondition $minTimestampCondition
LIMIT 1"""
}