文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

我们一起聊聊奇怪的SQL问题+1

2024-11-30 13:23

关注

我的 VIP 用户又抛给我一个 SQL 问题,我很激动,因为素材又来了:

我一看,这个表没什么花头,不就是没设置主键吗,MySQL 会默认生成一个主键,这跟 delete 不掉数据好像也没啥关系。

然后他说:

delete from a where device_id = '1239898' and task_id = '00111133445566';

这样删除不掉。

但是用 navicat 界面选择某一行点击删除可以删掉,然后他发现这样操作删除的 SQL 在尾部加上了  ESCAPE '#';

delete from a where device_id = '1239898' and task_id like '00111133445566' ESCAPE '#';

不知道为啥在界面手动删除用的是 like ,但是先不管,反正根据这个现象他暂时得出了一个结论,这个表的数据加ESCAPE '#'; 才删的掉。

我一听更兴奋了,这是什么奇怪的操作!

ESCAPE 是什么?

这个 ESCAPE 是一个关键字,它的作用其实很简单:替代转义的字符。

我们都知道跟 like 有关的 % 的作用,它能匹配任意多个字符。

比如 select * from a where name like '陈%';

这条语句就能把 a 表中姓陈的人都查找出来。

那现在有个人他叫“陈%2”,你只想找“陈%”开头的 name。

此时你就不能用 like '陈%',你需要用 like '陈 \ %%':

这里的 \ 就是转义符,它的作用是把紧跟后面的这个字符转义成正常的字符,不再具有它之前的含义(像 %之前的含义就是匹配任意多个字符)。

而 ESCAPE 的作用就是声明另一个字符来替换 \ 。

比如 select * from a where name like '陈#%%' ESCAPE "#";

这样一声明,# 就达到了 \ 的效果。

回到问题上来

现在我们已经明白了 ESCAPE 的作用,那么它跟开头的问题有什么关系吗?

我不知道,但是我很兴奋,我开始疯狂查阅资料。

google 无。

chatgpt 无。

newbing无。

MySQL官网无。

然后开始怀疑了:

好像看起来没什么特别的。

然后我又过了一遍跟他的聊天记录。

我直呼好家伙!!

他写的 SQL 是:

实际的数据是 :

所以他把两个条件写错了,task_id 是 1239898,device_id 才是那个一长串!!!

我估计这位同学之所以没看出来的原因是客户端手动删除的操作能删掉:

且产生了奇怪的  SQL,莫名加了  ESCAPE '#',让我们的这位同学一下子陷入了沉思。

实际上手动删除的 SQL 这么奇怪就是因为表没有主键,不然正常手动的删除 SQL 上 where 条件肯定是 id =xxx。

至于为什么加了 ESCAPE '#' 其实我也没懂,我查了查也也没查到。

如果知道的大佬欢迎留言指导下!

最后

所以,这并不是一个奇怪的 SQL 问题,只是一个小疏忽。

其实这种问题在编程上很常见,比如在 postman 调试的时候,分页数据写反了,pageSize写了1,pageNumer 写了 10 ,导致怎么查都没数据,怎么 debug 都看蒙了。

因为疏忽产生了很多奇奇怪怪、五花八门的问题,然后花了很多时间去找答案,还找不到。

最终沉下心来总的再过一遍才会发现,或者只能求助于同事。

我知道有问题,但是深陷其中当局者迷,花了两个小时还没解决,同事 10s 就能看出来。

所以遇到事情不要不好意思,要主动求助同事,不然那两个小时是真的痛苦!

来源:yes的练级攻略内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯