sql >> Databáze >  >> RDS >> Mysql

Zkontrolujte, zda všechny hodnoty v poli existují ve sloupci databáze

Efektivnější by bylo vytvořit příkaz s WHERE IN získat odpovídající e-maily a poté porovnat výsledná pole. Můžete použít array_diff() abyste získali rozdíl mezi poli.

<?php

mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);
$conn = mysqli_connect($servername, $username, $password, $db);

echo "Connected successfully\n";

$tags = preg_split("/\,/", $_POST['tags']);
$invalidEmails = array();
$count = 0;

// modify your array how you want it
foreach ($tags as $i => $tag) {
    $trim_brackets = trim($tag, '[]');
    $trim_quotes = trim($trim_brackets, '"');
    $tags[$i] = $trim_quotes;
}

// build placeholders for WHERE IN
$in = str_repeat('?,', count($tags) - 1) . '?';
// prepare query
$stmt = $conn->prepare("SELECT mail FROM dej_colleagues WHERE mail IN ($in)");
// bind an array of values. First params is a type list.
$stmt->bind_param(str_repeat('s', count($tags)), ...$tags);
$stmt->execute();
$results = $stmt->get_result();
// fetch the matching mails into an array
$mails = [];
foreach ($results as $row) {
    $mails[] = $row['mail'];
}

// get the difference between the two arrays
$invalidEmails = array_diff($tags, $mails);

if (count($tags) === count($mails)) {
    echo "good";
}

var_dump($invalidEmails);


  1. Jak mohu provést příkaz UPDATE s JOIN na SQL Server?

  2. Aktualizace MySQL trvá (příliš) dlouho

  3. Typy dat SQL VARCHAR Co dělat a co nedělat pro rychlejší databáze

  4. mysqli_query() očekává alespoň 2 parametry, z nichž 1 je uveden v?