connection->createQueryBuilder(); $qb->select('id', 'remote_addr') ->from('visits'); $st = $this->connection->executeQuery($qb->getSQL()); $qb = $this->connection->createQueryBuilder(); $qb->update('visits', 'v') ->set('v.remote_addr', ':obfuscatedAddr') ->where('v.id=:id'); while ($row = $st->fetch(PDO::FETCH_ASSOC)) { $addr = $row['remote_addr'] ?? null; if ($addr === null) { continue; } $qb->setParameters([ 'id' => $row['id'], 'obfuscatedAddr' => $this->determineAddress((string) $addr), ])->execute(); } } private function determineAddress(string $addr): ?string { if ($addr === IpAddress::LOCALHOST) { return $addr; } try { return (string) IpAddress::fromString($addr)->getAnonymizedCopy(); } catch (InvalidArgumentException) { return null; } } public function down(Schema $schema): void { // Nothing to rollback } public function isTransactional(): bool { return $this->connection->getDatabasePlatform()->getName() !== 'mysql'; } }