论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
朋友圈
看朋友圈动态,了解ToB世界。
ToB门户
了解全球最新的ToB事件
博客
Blog
排行榜
Ranklist
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
导读
Guide
相册
Album
记录
Doing
搜索
本版
文章
帖子
ToB圈子
用户
免费入驻
产品入驻
解决方案入驻
公司入驻
案例入驻
登录
·
注册
只需一步,快速开始
账号登录
立即注册
找回密码
用户名
Email
自动登录
找回密码
密码
登录
立即注册
首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
圈子
SAAS
ToB企服应用市场:ToB评测及商务社交产业平台
»
论坛
›
数据库
›
Oracle
›
当 SQL DELETE 邂逅 Table aliases,会擦出怎样的火花 ...
当 SQL DELETE 邂逅 Table aliases,会擦出怎样的火花
丝
金牌会员
|
2022-9-17 08:41:17
|
显示全部楼层
|
阅读模式
楼主
主题
856
|
帖子
856
|
积分
2568
开心一刻
晚上,女儿眼噙泪水躺在床上
女儿:你口口声声说爱我,说陪我,却天天想着骗我零花钱,你是我亲爹吗?
我:你想知道真相
女儿:想!
我:那你先给爸爸两百块钱!
环境准备
MySQL 不同版本
利用 docker 搭建了 7 个不同版本的 MySQL
5.5.62
5.6.51
5.7.36
8.0.15
8.0.16
8.0.17
8.0.30
当下最新版本
库与表
Table aliases
关于表别名,相信大家都不陌生;指定表别名是为了简化 SQL ,使可读性更强
语法如下
AS 可以省略
应用到 tbl_user 上则是
不仅表可以指定别名,列也可以指定别名,这里就不展开了
DELETE
对于 DELETE ,相信大家已经非常熟悉了
单表语法如下
多表语法如下
DELETE + Table aliases
SELECT 的时候,我们经常用表的别名
单表查询的时候
尤其是在连表查询的时候
那么 DELETE 的时候可以用别名吗,我们来试试
单表删除
通常情况下,删除语句这么写的
如果加上别名了,该怎么写
可能大家觉得很简单,楼主也觉得是如下这么写的
很有可能执行报错
,提示如下信息
我们来看下在 MySQL 各个版本的执行情况
可以看到,在 8.0.16 之前是会报错的
那 8.0.16 之前的正确写法应该是怎样的了,如下所示
当然, 8.0.16 及之后也是支持这两种写法的
也许是因为呼声太高,从 8.0.16 开始支持如下写法
官方说明
delete
连表删除
和单表删除基本一致,语法格式如下
删除 zhangsan 的登录日志,可以这么写
8.0.16 及之后是不是还可以这么写?
大家去试试,然后想想为什么
总结
1、单表删除的时候就别用别名了, SQL 更精简
2、如果要用别名,推荐用如下其中一种
更具通用性,方便迁移,而
需要 8.0.16 及之后版本才支持
3、连表删除的最后那个问题,大家可以从 从哪些表删除 来思考,对比下官方给的案例
应该就能想到答案了
参考
DELETE Statement
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
本帖子中包含更多资源
您需要
登录
才可以下载或查看,没有账号?
立即注册
x
回复
使用道具
举报
0 个回复
倒序浏览
返回列表
快速回复
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
or
立即注册
本版积分规则
发表回复
回帖并转播
回帖后跳转到最后一页
发新帖
回复
丝
金牌会员
这个人很懒什么都没写!
楼主热帖
ShardingSphere 异构迁移最佳实践:将3 ...
MySQL 5.7 安装教程(全步骤、保姆级教 ...
本科毕设CTF平台-MarsCTF
KubeEdge 1.12版本发布,稳定性、安全 ...
15.Linux和Windows入侵排查
Grafana 系列文章(一):基于 Grafana ...
Redis介绍与安装
mysql数据迁移,通用windows->linux,li ...
学生信息管理系统(JAVA+MYSQL) ...
还在写恶心的trim代码吗?用这个注解让 ...
标签云
挺好的
服务器
快速回复
返回顶部
返回列表