【MYSQL】业务上碰到的SQL问题整理集合

前言

身为一名前端工程师, 对于 SQL了解程度并不是很深刻, 盘点一些个人工作遇到的问题,给大家普及下知识, 以及记录自己如何解决这些问题的。

SELECT 查询语句不区分字母大小写?

相信这是一个非常常见的问题了, 而这个问题的原因主要还是表字符集引起的。

假设存在config表结构:

FieldTypeAllow NullDefault Value
keyvarchar(255)No 
valuevarchar(255)No 
idint(11)No 

表内数据如下:

keyvalueid
VERSION1.0.11
version2.0.12

执行语句为: 

  1. SELECT `key`,`value` FROM config WHERE `key` = 'version' LIMIT 1; 

期待结果:

keyvalue
version2.0.1

执行结果:

keyvalue
VERSION1.0.1


为什么会有这种现象?

mysql 默认对字符匹配排序大小写不敏感, 字段包括 varchar, char, text 内容. 如果要确实要区分大小写, 则在建表或者查表的时候使用 BINARY 属性. 二进制的 A 与 a 还是有区别的 ~~

解决方案1 : 修改sql语句

  1. SELECT `key`,`value` FROM config WHERE `key` = binary('version') LIMIT 1; 

或者

  1. SELECT `key`,`value` FROM config WHERE binary `key` = 'version' LIMIT 1; 

解决方案2 : 修改表结构

建表语句

  1. CREATE TABLE `config` ( 
  2.  
  3.   `keyBINARY varchar(255) NOT NULL
  4.  
  5.   `value` BINARY varchar(255) DEFAULT NULL
  6.  
  7.   `id` int(11) NOT NULL
  8.  
  9.   PRIMARY KEY (`id`) 
  10.  
  11. ) ENGINE=InnoDB DEFAULT CHARSET=utf8; 

修改表语句

  1. ALTER TABLE `config` MODIFY COLUMN `keyvarchar(255) BINARY NOT NULL

SELECT IN 语句顺序不符合传入时要求?

以config表为例, 表内数据:

keyvalueid
email[email protected]1
username2

SQL语句:

  1. SELECT `key`, `value` FROM `config` WHERE `keyIN ('username''email'); 

执行结果:

keyvalue
email[email protected]
username

明明是username 优先于 email, 结果却是 email优先于 username. 原因在于 IN 查询只负责查询, 不负责排序, 而默认排序是用 id asc, 所以得到了一个不符合IN查询的结果

解决方案

  1.     使用 ORDER BY FIELD()
  2.     使用 ORDER BY FIND_IN_SET() 
  1. SELECT `key`, `value` FROM `config` WHERE `keyIN ('username''email'ORDER BY FIELD('key','username''email'); 

或者

  1. SELECT `key`, `value` FROM `config` WHERE `keyIN ('username''email'ORDER BY FIND_IN_SET(`key`,'username,email'); 

最终执行结果:

keyvalue
username
email[email protected]

注意: FIND_IN_SET 第二个参数 strlist 逗号之间不需要空格

SELECT 存储查询生僻汉字, 结果乱码 ?

前提,数据库和表都是采用的是utf8字符集.

生僻字比如: 𠂤

  1. INSERT INTO `config` (`key`,`value`,`id`) VALUES ('word''𠂤', 7); 

查询SQL:

  1. SELECT * FROM `config` WHERE `key` = 'word' LIMIT 1; 

执行结果:

valuekeyid
word????7

出现了???? 这种情况,难道说 utf8字符集没有记录这个生僻字么?

mysql 支持的 utf8 编码***字符长度为 3 字节,如果遇到 4 字节的宽字符就会插入异常了。三个字节的 UTF-8 ***能编码的 Unicode 字符是 0xffff,也就是 Unicode 中的基本多文种平面(BMP)。也就是说,任何不在基本多文本平面的 Unicode字符,都无法使用 Mysql 的 utf8 字符集存储。包括 Emoji 表情(Emoji 是一种特殊的 Unicode 编码,常见于 ios 和 android 手机上),和很多不常用的汉字,以及任何新增的 Unicode 字符等等。

引用一段 关于 MySQL UTF8 编码下生僻字符插入失败/假死问题的分析 内容

解决方案:

修改字符集

  1. --修改数据库字符集 
  2. ALTER DATABASE test CHARACTER SET = utf8mb4; 
  3. --修改表字符集 
  4. alter table `config` convert to character set utf8mb4; 
  5. --修改字符字符集 
  6. ALTER TABLE `config` CHANGE COLUMN `value` `value` varchar(12) CHARACTER SET utf8mb4; 

最终执行sql

  1. - 设置连接 socket 使用字符集 
  2.  
  3. SET NAMES utf8mb4; 
  4.  
  5. - 修改表字段字符集 
  6.  
  7. ALTER TABLE `config` CHANGE COLUMN `value` `value` varchar(12) CHARACTER SET utf8mb4; 
  8.  
  9. - 更新值 
  10.  
  11. UPDATE `config` SET `value` = '𠂤' WHERE `key` = 'word'
  12.  
  13. - 查询 
  14.  
  15. SELECT * FROM `config` WHERE `key` = 'word'

执行结果

keyvalueid
word𠂤7

SELECT LOCATE 与 LIKE 区别使用

同样再使用config表举一个例子, 假如有以下的行数据:

keyvalueid
app.version1.0.08
h5.version1.0.19
app.email[email protected]10
h5.email[email protected]11

LIKE语句

如果我们想要查询以app 或 h5 开头的命名空间的所有配置项, 可以使用LIKE语句

  1. SELECT `key`, `value` FROM `config` WHERE `keyLIKE 'h5.%';

执行结果:

keyvalue
h5.version1.0.1
h5.email[email protected]

如果想去掉h5命名空间前缀, 可以使用 substring 函数

  1. SELECT substring(`key`, length('h5.') + 1), `value` FROM `config` WHERE `keyLIKE 'h5.%'

执行结果:

keyvalue
version1.0.1
email[email protected]

LIKE 在字符串全匹配,以及前置查询如 h5.%的时候, 如果存在索引会有一定的优化作用。不会进行全表扫描

LOCATE 函数

LOCATE是一种查询匹配字符串出现次数的函数

执行语句:

 

  1. SELECT `key`, `value` FROM `config` WHERE LOCATE('app',`key`) > 0; 

执行结果:

keyvalue
app.version1.0.0
app.email[email protected]

经过相关资料的学习, 最终认为LIKE的效率与LOCATE的效率是无法对比谁快谁慢,相关文章推荐阅读 MySQL LIKE vs LOCATE

总结

mysql, sql 里面的知识确实让人感觉深奥. 此时此刻我只是解决了我遇到问题, 一会也会遇到更多不一样的问题, 而这也是学习sql, 计算机的魅力. 以后遇到更多的关于SQL的问题, 会不断更新…

欢迎大家收藏和点赞!!! 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/265573.html<

(0)
运维的头像运维
上一篇2025-05-05 13:38
下一篇 2025-05-05 13:40

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注