MySQL-delete tableName from ...

前言

今天刷SQL题的时候遇到一个没见过的SQL写法:delete tableName from ..., 看到这个写法脑子突然有点痒了,接着就是一系列疑问。这个写法学过吗?我不是刚学完基础语法吗?我怎么没见过这个写法?这个能运行吗?这个语法是意思?不应该是 delete from tableName...吗?

一、有没有这个语法?

由于刚复习完基础语法,我的第一反应就是没有这个语法。所以我又在学习笔记了找了找了确实没有这个介绍这个语法,那别的同学有记录吗?找了几位同学的博客发现也没有。那么就实锤了在学基础语法的时候这个语法根本就没有介绍。

**二、**这个语法是意思?

没学过,不知道是什么意思,所以问了一下AI,还真有解释还挺详细。

实例:196. 删除重复的电子邮箱 - 力扣(LeetCode)

这里官方使用了自连接查询进行删除数据,用到了一下SQL:

sql 复制代码
DELETE p1 
FROM Person p1,
     Person p2
WHERE
    p1.Email = p2.Email AND p1.Id > p2.Id
1. DELETE p1 的含义
  • DELETE 是 SQL 的删除命令。
  • p1Person 表的别名 (在 FROM 子句中定义)。
  • DELETE p1 明确表示:只删除来自别名为 p1 的表(即 Person 表)的行

关键点 :这里 p1p2 都指向同一个物理表 Person,但通过别名,我们将其视为两个逻辑上的"副本"来进行自连接操作。DELETE p1 指定的是删除 p1 这个"副本"所代表的行。


总结

DELETE p1 在这个语句中,是 MySQL 特有的语法,用于指定在多表(或自连接)操作中,具体要删除哪个表(或其别名)的行

相关推荐
倔强的石头_14 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
于眠牧北2 天前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
李广坤3 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12024 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区4 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1774 天前
《从零搭建NestJS项目》
数据库·typescript
加号34 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏5 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐5 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端