connection->createQueryBuilder(); $qb->select('id', 'remote_addr') ->from('visits'); $st = $this->connection->executeQuery($qb->getSQL()); $qb = $this->connection->createQueryBuilder(); $qb->update('visits') ->set('remote_addr', ':obfuscatedAddr') ->where('id=:id'); while ($row = $st->fetchAssociative()) { $addr = $row['remote_addr'] ?? null; if ($addr === null) { continue; } $qb->setParameters([ 'id' => $row['id'], 'obfuscatedAddr' => $this->determineAddress((string) $addr), ])->executeQuery(); } } 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() instanceof MySQLPlatform); } }