This is part of the Semicolon&Sons Code Diary - consisting of lessons learned on the job. You're in the rails category.
Last Updated: 2025-01-18
The following code generates an in
clause for the taxonomy
bit:
subject_taxons = Taxon.where(taxonomy: Taxonomy.overall_subject)
Here is the SQL generated:
SELECT taxons.* FROM taxons
WHERE taxons.taxonomy_id IN (SELECT
taxonomies.id FROM taxonomies WHERE taxonomies.name = 'Subject'
)
I merged in another SQL IN
clause to the scope above, expecting that the
results would be filtered to taxons that were members of both taxonomies.
institution_taxons = Taxon.where(taxonomy: Taxonomy.institution)
subject_taxons.merge(institution_taxons)
This gave the following SQL
SELECT taxons.* FROM taxons
WHERE taxons.taxonomy_id IN (SELECT
taxonomies.id FROM taxonomies WHERE taxonomies.name = 'Subject'
)
I.e. what happened was that the last/final SQL in clause had overwritten the first one in the sequence of merges.
This is probably a difficult problem to solve, in that it is vague whether I meant either to grab taxons - both in the subject AND institution taxonomies - either in the subject OR institution taxonomies
ActiveRecord#merge
does not handle multiple SQL IN ()
clauses.