MySQL中两个表字段名相同导致的一个问题

  今天在对两个表进行查询的时候,由于两个表的有已个字段名是相同的,最终导致了查询结果不是我要的,该问题导致我检查了很久啊。大致如下:

表A字段:

PID,PName,PNote

表B字段:

PID,Money,PayDate

查询语句如下:

SELECT PID,PName,(SELECT SUM(Money) FROM B WHERE PID=PID) TotalMoney ,PNote,(SELECT PayDate FROM B          WHERE PID=PID ORDER BY PayDate DESC LIMIT 1) LastDate

FROM A

 

本来是想使用A表的值去在B表进行查询的,可最后返回的是所有的记录.最后发现是PID=PID的问题。最后我的解决方案是将PID赋值给另一个变量解决的。

如:

SELECT @PD:=PID P,PName,(SELECT SUM(Money) FROM B WHERE PID=@PD) TotalMoney ,PNote,(SELECT PayDate FROM B          WHERE PID=@PD ORDER BY PayDate DESC LIMIT 1) LastDate

FROM A

不知道还有没有好方法了

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值