deedar 2024-08-23 11:48 采纳率: 0%
浏览 6

【疑问】mybatis连接pgsql数据库left join两种写法,一种报错一种不报错

mybatis中sql语句对比

连接的是pgsql数据库,
第一种写法,一直报错“Must have sharding column with subquery”

select 
t1.data, 
t1.prov_code, 
(case when t2.data_no is not null then '01' else '00' end) modifiable
from tbl_info t1
left join 
( select t3.data_no, t3.type from tbl_dic t3 where t3.type = '001') t2 on t1.prov_code = t2.data_no 
where t1.date = '20240508'

第二种写法,可以正常执行

select 
t1.data, 
t1.prov_code, 
(case when t2.data_no is not null then '01' else '00' end) modifiable
from tbl_info t1
left join tbl_dic t2 on t1.prov_code = t2.data_no and t2.type = '001'
where t1.date = '20240508'

但是我感觉两种意思是一样的,在dbever也都能正常执行,可是放进mybatis里执行效果却大不相同,想知道为什么

  • 写回答

2条回答 默认 最新

  • shinelord明 2024-08-23 16:10
    关注

    1.如果有mapper.xml看一下配置是否正确。
    2.看意思是需要在子查询有对应的列字段,需要分区?表结构设计?

    评论

报告相同问题?

问题事件

  • 创建了问题 8月23日

悬赏问题

  • ¥15 在虚拟机中安装flash code
  • ¥15 单片机stm32f10x编写光敏电阻调节3.3伏大功率灯亮度(光强越大灯越暗,白天正常光强灯不亮,使用ADC,PWM等模块)望各位找一下错误或者提供一个可实现功能的代码
  • ¥20 verilog状态机方法流水灯
  • ¥15 pandas代码实现不了意图
  • ¥15 GD32H7 从存储器到外设SPI传输数据无法重复启用DMA
  • ¥25 LT码在高斯信道下的误码率仿真
  • ¥45 渲染完成之后将物体的材质贴图改变,自动化进行这个操作
  • ¥15 yolov5目标检测并显示目标出现的时间或视频帧
  • ¥15 电视版的优酷可以设置电影连续播放吗?
  • ¥50 复现论文;matlab代码编写