Home > Database > Mysql Tutorial > Why Doesn't MySQL IN() Query Return Rows with Multiple Matching IDs?

Why Doesn't MySQL IN() Query Return Rows with Multiple Matching IDs?

Susan Sarandon
Release: 2024-11-04 16:38:02
Original
904 people have browsed it

Why Doesn't MySQL IN() Query Return Rows with Multiple Matching IDs?

MySQL IN () Query Issue for Multi-ID Records

When executing the query:

SELECT * FROM table WHERE id IN (1,2,3,4);
Copy after login

to retrieve data based on multiple IDs, you may encounter an issue where rows containing multiple matching IDs are not returned. This query translates to:

SELECT * FROM table WHERE id='1' or id='2' or id='3' or id='4';
Copy after login

which retrieves only rows that match any single ID in the set.

Solution: Using SET Datatype

To address this limitation, you can consider altering the id column's datatype to SET. This allows you to store multiple values in a single column. After making this change, you can use the FIND_IN_SET function in your query:

SELECT * FROM table WHERE FIND_IN_SET('1', id);
Copy after login

This query will return all rows that contain '1' as one of the values in the id column, regardless of any other values present. This provides a more flexible way of matching records with multiple IDs.

The above is the detailed content of Why Doesn't MySQL IN() Query Return Rows with Multiple Matching IDs?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template