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 特有的语法,用于指定在多表(或自连接)操作中,具体要删除哪个表(或其别名)的行

相关推荐
我是一颗柠檬3 小时前
【MySQL全面教学】MySQL面试高频考点汇总Day15(2026年)
数据库·后端·mysql·面试
凯瑟琳.奥古斯特4 小时前
高阶子查询题目精炼
开发语言·数据库·python·职场和发展·数据库开发
身如柳絮随风扬4 小时前
数据库读写分离:从原理到实战,构建高并发系统
数据库·mysql
提笔了无痕5 小时前
RAG存储策略中.md格式的切片与存储怎么处理
数据库·ai·rag
陳土5 小时前
DuckDB精读——基于Getting started with DuckDB
数据库·oracle
凯瑟琳.奥古斯特6 小时前
数据库原理选择题精选
数据库·python·职场和发展
曹牧6 小时前
C#:主线程能够捕获到子线程中的异常
开发语言·数据库·c#
朝阳5816 小时前
MongoDB 副本集从零搭建到生产可用
数据库·mongodb