data:image/s3,"s3://crabby-images/d3cb4/d3cb4c47d18b2df7b3bffe505e78b71e20172d70" alt=""
Insert entry if it doesn’t exist in MySQL
Yes, that’s probably a common issue – you want to make insert in MySQL only if a duplicate does not exist. I faced this issue today, and since it took me some time to figure out a way to do it (to be honest – a colleague gave me the query) – I’m sharing it here. Oh, and thanks for it, Vasko!
So it’s actually not that complicated, or not as much as I though when I started the task. We need to build a query, that will make this at once.
Let’s say we have a table with book titles with fields `lang_id` and `title` – which we need to check for duplicates. So let’s say we need to add two books ‘Crime and Punishment’ with language code 23 and ‘The Black OBelisk’ with language code 23. The query will be:
INSERT INTO `books` (`lang_id`, `title`)
SELECT `lang_id`, `title` FROM
(
(SELECT 23 AS `lang_id`, 'Crime and Punishment' AS `title`)
UNION
(SELECT 23 AS `lang_id`, 'The Black OBelisk' AS `title`)
) t_union
WHERE `title` NOT IN (SELECT `title` FROM `books` WHERE `lang_id` = 23);
This is nice, but how do we build it in PHP? Well, even simpler:
We create a function:
function updateBooks($langId, $titles)
{
$sql = <<<___SQL
INSERT INTO `books` (`lang_id`, `title`)
SELECT lang_id, `title` FROM
(
___SQL;
$values = [];
$queries = [];
foreach ($titles as $title) {
$queries[] = "(SELECT ? AS `lang_id`, ? AS `title`)";
$values[] = $langId;
$values[] = $title;
}
$sql .= implode(" UNION ", $queries);
$sql .= <<<___SQL
) t_union
WHERE `title` NOT IN (SELECT `title` FROM `books` WHERE `lang_id` = ?)
___SQL;
$values[] = $langId;
$this->db->query($sql, $values);
}
This method takes the `lang_id` as first parameter and array of titles as the second. I’ve intentionally have not gone into details on the DB execution – this is a topic for another guide. Hope this helps.
Similar blog posts
data:image/s3,"s3://crabby-images/7f791/7f791feda1b82f09e767812ceddab0f2c14ba7b2" alt=""
Elasticsearch cheat sheet
Search Count AND query OR query Query with date range Multiple Queries Or a query inside a query Sort by a date containing field Query with regex Point In Time...data:image/s3,"s3://crabby-images/cb299/cb299469ae5e8c4c22bf380dba44ccacac9c531e" alt=""
Odroid Sensors
Not long ago I bought an Odroid ARM based mini PC, and among many issues, turned out that the system uses some rather strange scheme for controlling the fan speed....data:image/s3,"s3://crabby-images/3482e/3482e81b4f73e66a6e3f4667fe7b2ddb1abd40fa" alt=""
“Kubernetes network isn’t reliable”
Recently, while trying to figure out an extrelemly annoying problem I was having with Kubernetes – I stumbled upon this marvel of a github issue. So if you ever need...data:image/s3,"s3://crabby-images/a650b/a650b0209506d049cec8dea1233fe53c27e7b2a6" alt=""