Mysql ERROR 1093 (HY000) 错误解决

.版本

1)操作系统

cat /etc/issue
CentOS release 6.6 (Final)
Kernel \r on an \m

cat /proc/version
Linux version 2.6.32-504.el6.x86_64 (mockbuild@c6b9.bsys.dev.centos.org) (gcc version 4.4.7 20120313 (Red Hat 4.4.7-11) (GCC) ) #1 SMP Wed Oct 15 04:27:16 UTC 2014

2)mysql数据库版本

MySQL --version
MySQL  Ver 14.14 Distrib 5.6.26, for linux-glibc2.5 (x86_64) using  EditLine wrapper


2.问题描述

2.1 发现问题

   在工作过程中遇到过如下的报错:

DELETE FROM cs_user_cp WHERE id IN (
    ->            SELECT cp.id FROM  cs_user_cp cp ,`cs_category_process` p,cs_user u,`cs_position` post WHERE cp.`category_process_id` = p.id  AND u.id = cp.user_id  AND u.`position_code` = post.id AND  p.company_id <> post.company_id);
ERROR 1093 (HY000): You can't specify target table 'cs_user_cp' for update in FROM clause

3.问题分析

   这是因为Mysql 中Delete和Update 语句,不允许子查询中出现update和delete要操作表

4.解决方案

   我们可以通过如下两种变通的方法来解决该问题

方案1

给子查询外面再加一个查询

DELETE FROM cs_user_cp WHERE id IN(SELECT * FROM (
           SELECT cp.id FROM  cs_user_cp cp ,`cs_category_process` p,cs_user u,`cs_position` post WHERE cp.`category_process_id` = p.id  AND u.id = cp.user_id  AND u.`position_code` = post.id AND  p.company_id <> post.company_id) s )


方案2

delete 语句中使用join

DELETE cs_user_cp from cs_user_cp join  (
           SELECT cp.id FROM  cs_user_cp cp ,`cs_category_process` p,cs_user u,`cs_position` post WHERE cp.`category_process_id` = p.id  AND u.id = cp.user_id  AND u.`position_code` = post.id AND  p.company_id <> post.company_id) s on cs_user_cp.id=s.id;





错误代码 4058 (HY000) 是 MySQL 8 数据库管理系统发生的一种错误。并且这种错误通常是由于访问权限或服务器配置问题引起的。MySQL 8.0.11 或以上版本中会显示以下错误消息: 「ERROR 4058 (HY000):Column '%-.192s' cannot be part of FULLTEXT index」。 发生这种错误时,MySQL 8 用户需要检查访问权限和服务器配置。 可能是由于以下一些原因: 1. 用户没有权限创建全文索引 2. 数据表不存在或被删除 3. 数据表中没有可用的列 4. 索引名称与系统保留关键字相同 5. MySQL 8 安装配置的问题 解决这些问题需要进行逐一检查,然后对问题进行解决。 首先,用户需要检查其数据库管理系统的安装和配置是否正确。如果安装或配置出现问题,请参考 MySQL 官方文档以获得解决问题的方法。 其次,用户需要检查是否有足够的权限来执行要求的操作。如果没有权限,可以联系管理员或使用类似 GRANT 命令的 SQL 命令来授予所需的权限。 然后,用户需要检查数据表是否存在,并确保其结构正确。可以使用 SHOW TABLES 或 DESCRIBE 命令来验证数据表的存在和结构。 最后,如果出现索引名称与系统保留关键字相同的问题,用户应更改索引名称,以避免与系统保留关键字冲突。 总之,MySQL 8 数据库管理系统的错误 4058 (HY000) 可能由权限或服务器配置问题引起。对于用户来说,需要逐一检查各种可能的问题,以便找到解决方案并修复所遇到的错误
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

渔夫数据库笔记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值