MYSQL Duplicate column name ‘FId‘解决记录

2024-03-06 07:32

本文主要是介绍MYSQL Duplicate column name ‘FId‘解决记录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前因:在优化sql的时候,在from里面嵌套子查询缩小结果集。

先写一下下面建表、连表查询的大概关系。

CREATE TABLE `table_a` (`FID` VARCHAR(32) NOT NULL COMMENT 'ID' COLLATE 'utf8_general_ci',`Fname` VARCHAR(8) NULL DEFAULT NULL COMMENT '名称' COLLATE 'utf8_general_ci',`Fphone` VARCHAR(20) NULL DEFAULT NULL COMMENT '电话' COLLATE 'utf8_general_ci',PRIMARY KEY (`FID`) USING BTREE,
)
COMMENT='a'
COLLATE='utf8_general_ci'
ENGINE=InnoDB
;
CREATE TABLE `table_b` (`FID` VARCHAR(32) NOT NULL COMMENT 'ID' COLLATE 'utf8_general_ci',`Fproject` VARCHAR(8) NULL DEFAULT NULL COMMENT '名称' COLLATE 'utf8_general_ci',`FName` VARCHAR(20) NULL DEFAULT NULL COMMENT '电话' COLLATE 'utf8_general_ci',`Fseq` VARCHAR(20) NULL DEFAULT NULL COMMENT '电话' COLLATE 'utf8_general_ci',PRIMARY KEY (`FID`) USING BTREE,
)
COMMENT='b'
COLLATE='utf8_general_ci'
ENGINE=InnoDB
;
CREATE TABLE `table_b` (`FID` VARCHAR(32) NOT NULL COMMENT 'ID' COLLATE 'utf8_general_ci',`Fname` VARCHAR(8) NULL DEFAULT NULL COMMENT '名称' COLLATE 'utf8_general_ci',`Ftable` VARCHAR(20) NULL DEFAULT NULL COMMENT '电话' COLLATE 'utf8_general_ci',PRIMARY KEY (`FID`) USING BTREE,
)
COMMENT='b'
COLLATE='utf8_general_ci'
ENGINE=InnoDB
;
select a.Fid,a.Fname,a.Fphone,b.Fname,b.Fproject,b.Fseq,c.Ftable,c.Fname
from table_a a
left join table_ b b on a.Fid = b.Fid 
left join table_c c on a.Fid = c.Fid
where 1=1

再写一个出问题的SQL

select a.Fid,a.Fname,a.Fphone,b.Fname,b.Fproject,b.Fseq,c.Ftable,c.Fname
from (
select * from table_a a
left join table_b b on a.Fid = b.Fid 
where b.Fproject = 'xxx'
) a
left join table_ b b on a.Fid = b.Fid 
left join table_c c on a.Fid = c.Fid
where 1=1

这里运行的时候就会出现报这个错:
Duplicate column name ‘FId’

这是为什么呢?
其实原因很简单,因为在子查询里面select *了,这里不但会返回table_a的字段,也会返回table_b的字段,这两个字段重复了,知道问题就好修改了,考虑到业务上返回其实只需要table_a的字段,所以将上面子查询select *from 修改成 select a.*from就可以了。

同时说一下添加子查询的优化思路:
在from里面嵌套子查询缩小结果集,在多张大表联表查询的时候这样优化sql,性能可以提升很多的。

这篇关于MYSQL Duplicate column name ‘FId‘解决记录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/779286

相关文章

JAVA Calendar设置上个月时,日期不存在或错误提示问题及解决

《JAVACalendar设置上个月时,日期不存在或错误提示问题及解决》在使用Java的Calendar类设置上个月的日期时,如果遇到不存在的日期(如4月31日),默认会自动调整到下个月的相应日期(... 目录Java Calendar设置上个月时,日期不存在或错误提示java进行日期计算时如果出现不存在的

Mybatis对MySQL if 函数的不支持问题解读

《Mybatis对MySQLif函数的不支持问题解读》接手项目后,为了实现多租户功能,引入了Mybatis-plus,发现之前运行正常的SQL语句报错,原因是Mybatis不支持MySQL的if函... 目录MyBATis对mysql if 函数的不支持问题描述经过查询网上搜索资料找到原因解决方案总结Myb

Nginx错误拦截转发 error_page的问题解决

《Nginx错误拦截转发error_page的问题解决》Nginx通过配置错误页面和请求处理机制,可以在请求失败时展示自定义错误页面,提升用户体验,下面就来介绍一下Nginx错误拦截转发error_... 目录1. 准备自定义错误页面2. 配置 Nginx 错误页面基础配置示例:3. 关键配置说明4. 生效

MySQL 筛选条件放 ON后 vs 放 WHERE 后的区别解析

《MySQL筛选条件放ON后vs放WHERE后的区别解析》文章解释了在MySQL中,将筛选条件放在ON和WHERE中的区别,文章通过几个场景说明了ON和WHERE的区别,并总结了ON用于关... 今天我们来讲讲数据库筛选条件放 ON 后和放 WHERE 后的区别。ON 决定如何 "连接" 表,WHERE

mysql_mcp_server部署及应用实践案例

《mysql_mcp_server部署及应用实践案例》文章介绍了在CentOS7.5环境下部署MySQL_mcp_server的步骤,包括服务安装、配置和启动,还提供了一个基于Dify工作流的应用案例... 目录mysql_mcp_server部署及应用案例1. 服务安装1.1. 下载源码1.2. 创建独立

Mysql中RelayLog中继日志的使用

《Mysql中RelayLog中继日志的使用》MySQLRelayLog中继日志是主从复制架构中的核心组件,负责将从主库获取的Binlog事件暂存并应用到从库,本文就来详细的介绍一下RelayLog中... 目录一、什么是 Relay Log(中继日志)二、Relay Log 的工作流程三、Relay Lo

MySQL日志UndoLog的作用

《MySQL日志UndoLog的作用》UndoLog是InnoDB用于事务回滚和MVCC的重要机制,本文主要介绍了MySQL日志UndoLog的作用,文中介绍的非常详细,对大家的学习或者工作具有一定的... 目录一、Undo Log 的作用二、Undo Log 的分类三、Undo Log 的存储四、Undo

Java调用DeepSeek API的8个高频坑与解决方法

《Java调用DeepSeekAPI的8个高频坑与解决方法》现在大模型开发特别火,DeepSeek因为中文理解好、反应快、还便宜,不少Java开发者都用它,本文整理了最常踩的8个坑,希望对... 目录引言一、坑 1:Token 过期未处理,鉴权异常引发服务中断问题本质典型错误代码解决方案:实现 Token

MySQL游标和触发器的操作流程

《MySQL游标和触发器的操作流程》本文介绍了MySQL中的游标和触发器的使用方法,游标可以对查询结果集进行逐行处理,而触发器则可以在数据表发生更改时自动执行预定义的操作,感兴趣的朋友跟随小编一起看看... 目录游标游标的操作流程1. 定义游标2.打开游标3.利用游标检索数据4.关闭游标例题触发器触发器的基

springboot3.x使用@NacosValue无法获取配置信息的解决过程

《springboot3.x使用@NacosValue无法获取配置信息的解决过程》在SpringBoot3.x中升级Nacos依赖后,使用@NacosValue无法动态获取配置,通过引入SpringC... 目录一、python问题描述二、解决方案总结一、问题描述springboot从2android.x