MySQL删除数据1093错误

 更新时间:2024年02月04日 11:32:52   作者:早起的年轻人  
在进行更新和删除操作的时候,条件语句里面有子查询语句,此时会报1093错误,本文就来介绍一下1093错误的解决,感兴趣的可以了解一下

现象:在进行更新和删除操作的时候,条件语句里面有子查询语句,此时会报1093错误!
错误日志:1093 - You can’t specify target table ‘t_suer_study_video’ for update in FROM clause

首先根据条件来查询

SELECT * FROM t_suer_study_video WHERE video_course_id =207;

如下图所求,其中有一个用户有两条数据,train_id 为 null 的那一条数据为重复数据,我需要删除的。

在这里插入图片描述

线上环境中,像上页面这样的数据,不小心产生了几千条,是写的程序的一个bug导致的问题,所以我需要批量删除,先按用户ID分组查询一下:

SELECT user_id, COUNT(*) FROM t_suer_study_video WHERE video_course_id =207 GROUP BY user_id;  

如下图,数量为2的用户的数据就是需要处理的

在这里插入图片描述

然后筛选分组的用户数据

SELECT
	user_id,
	COUNT(*) 
FROM
	t_suer_study_video 
WHERE
	video_course_id = 207 
GROUP BY
	user_id 
HAVING
	COUNT(*) > 1;

我这测试数据,只有一个用户的是重复的,实际中是有多个用户的

在这里插入图片描述

然后删除重复的,就是将上述分组查询出来的重复用户的ID作为条件来删除

DELETE 
FROM
	t_suer_study_video 
WHERE
	video_course_id = 207 
	AND train_id IS NULL 
	AND user_id IN (
					SELECT
						user_id 
					FROM
						t_suer_study_video 
					WHERE
						video_course_id = 207 
					GROUP BY
						user_id 
					HAVING
					COUNT(*) > 1 
	);

出现错误 1093 - You can’t specify target table ‘t_suer_study_video’ for update in FROM clause

在这里插入图片描述

原因:在进行更新和删除操作的时候,条件语句里面有子查询语句,此时会报1093错误!,MySQL在进行读取数据的时候 会加读锁(共享锁),其他请求可以再次加上读锁,但是不能加写锁,(如果在读的过程中,又有其他线程进行了更新操作,就会导致当前线程读取到的数据不是最新的数据,这就是不可重复读现象)。因此不支持对数据更新的同时进行查询操作,加了读锁 就不允许加写锁。

解决办法:外面多嵌套一层查询,原先的查询作为子查询。

DELETE 
FROM
	t_suer_study_video 
WHERE
	video_course_id = 207 
	AND train_id IS NULL 
	AND user_id IN (
				SELECT
					a.user_id 
				FROM
					(
							SELECT
								user_id 
							FROM
								t_suer_study_video 
							WHERE
								video_course_id = 207 
							GROUP BY
								user_id 
							HAVING
								COUNT(*) > 1 
					) a 
	);

删除成功

在这里插入图片描述

 到此这篇关于MySQL删除数据1093错误的文章就介绍到这了,更多相关MySQL 1093错误内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 关于Mysql子查询的三个应用场景

    关于Mysql子查询的三个应用场景

    这篇文章主要介绍了关于Mysql子查询的三个应用场景,子查询是在一个完整的查询语句中,嵌套不同功能的小查询,从而完成复杂查询的一种编写形式,需要的朋友可以参考下
    2023-07-07
  • mysql 5.7.14 下载安装、配置与使用详细教程

    mysql 5.7.14 下载安装、配置与使用详细教程

    这篇文章主要介绍了mysql 5.7.14 下载安装、配置与使用详细教程的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-09-09
  • 简单了解 MySQL 中相关的锁

    简单了解 MySQL 中相关的锁

    这篇文章主要介绍了简单了解 MySQL 中相关的锁,重点介绍InnoDB中的锁相关知识,包括锁的概念及分类解析,对MySQL锁相关感兴趣的朋友跟随小编一起看看吧
    2021-05-05
  • mysql 乐观锁和悲观锁的具体使用

    mysql 乐观锁和悲观锁的具体使用

    本文主要介绍了mysql 乐观锁和悲观锁的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-01-01
  • MYSQL中常用的强制性操作(例如强制索引)

    MYSQL中常用的强制性操作(例如强制索引)

    对于经常使用oracle的朋友可能知道,oracle的hint功能种类很多,对于优化sql语句提供了很多方法。同样,在mysql里,也有类似的hint功能。
    2014-05-05
  • MySQL中的JSON_CONTAINS函数举例详解

    MySQL中的JSON_CONTAINS函数举例详解

    这篇文章主要给大家介绍了关于MySQL中JSON_CONTAINS函数举例详解的相关资料,MySQL JSON_CONTAINS函数可用于判断JSON数组中是否包含某个元素,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2023-12-12
  • Windows10下mysql 5.7.17 安装配置方法图文教程

    Windows10下mysql 5.7.17 安装配置方法图文教程

    这篇文章主要为大家详细介绍了Windows10下mysql5.7.17安装配置方法图文教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-02-02
  • MySQL通过实例化对象参数查询实例讲解

    MySQL通过实例化对象参数查询实例讲解

    在本篇文章里我们给大家分享了关于MySQL如何通过实例化对象参数查询数据的相关知识点内容,有需要的朋友们可以测试参考下。
    2018-10-10
  • mysql中insert ignore、insert和replace的区别及说明

    mysql中insert ignore、insert和replace的区别及说明

    这篇文章主要介绍了mysql中insert ignore、insert和replace的区别及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • MySQL5.x版本乱码问题解决方案

    MySQL5.x版本乱码问题解决方案

    这篇文章主要介绍了MySQL5.x版本乱码问题解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09

最新评论