The phenomenon of
A problem encountered when using MySQL string queries is that queries are case insensitive, as shown in the figure belowWhen querying name, use A to query or use A to query, the result is the same.
Limit the scope of discussion
- Only table creation is discussed;
- Only case queries for column values in a table are discussed.
- Only the character set encoding UTF8, collation utf8_general_CI, utf8_bin;
why
MySQL character set and collation rules
When creating a table, you can specify the character set and collation of the table, as well as the character set collation of the column. This article does not discuss the effect of database level configuration on column character sets and collations. What affects the query result is the collation of the column. In the query result shown above, the collation of the name field is UTF8_general_CI. If you run the command to change the sorting rule of the name column to UTf8_bin, the query is case-sensitive, as shown in the following figure.Once the character set is determined, it is the collation of columns that affects whether the query supports case or not.
conclusion
A character set is a set of symbols and codes, and a collation is a set of rules for comparing characters within a character set. Only for the MySQL utF8 character set, the English letter “A” and “A” encoding stored in disk, so the read data is case sensitive. In the query, obtain utF8 decoded characters from the disk and compare them by sorting rules. If UTF8_general_CI is used, the query is case insensitive; if UTF8_bin is used, the query is case sensitive.