mysql报错:Column 'id' in field list is ambiguous,以及tp的三表联合查询语句,打印sql等

一、报错信息

1、报错信息

单纯的根据报错信息,意思是在联合查询中,这几个表的都有id值,mysql在执行查询中,不能分辨id是属于哪个表的。

bash 复制代码
解决方案:
1、修改表字段,不要都叫id  (这个方案不好)
2、给表起别名 (我已经起了,所以这条对我没用)

2、贴代码

scss 复制代码
//这个是三表联合查询,利用一些字段关联查询的,但一直报错
$arr = M('smj_evaluate')->alias('e')
      ->field('e.content','e.star','u.openid','o.orderid')
      ->join(' smj_userinfo  u ON e.uid = u.id')
      ->join(' smj_order o ON e.order_id = o.id')
      ->limit($p->firstRow,$p->listRows)
      ->order('e.id')
      ->where('e.status=0')
      ->select();
    var_dump($arr);

二、问题所在

上面这个问题困扰我很久。后来在一个同学的帮助下才知道问题所在。由于博主一直用的都是laravel,所以对tp3.2.3是在是陌生的不得了,在写sql的时候,不自觉的就写成了laravel的方式,实在是粗心。

1、正确代码

scss 复制代码
 $arr = M('smj_evaluate')->alias('e')
      ->field('e.content,e.star,u.openid,o.orderid')
      ->join(' smj_userinfo  u ON e.uid = u.id')
      ->join(' smj_order o ON e.order_id = o.id')
      ->limit($p->firstRow,$p->listRows)
      ->order('e.id')
      ->where('e.status=0')
      ->select();
    var_dump($arr);

大家对比一下就能发现,关键就是field括号里面的不同。在laravel中,查询某些字段都是要分开查的。但是在tp中,field中的所有字段都必须要在同一个单引号中。

三、关于打印sql语句的问题

1、利用getLastSql()方法打印

scss 复制代码
//在执行完sql之后,执行getLastSql()方法
   $sql = M('smj_evaluate')->getLastSql();
    var_dump($sql);

此方法会返回原生的sql语句。例如:

scss 复制代码
string(199) "SELECT e.content,e.star,u.openid,o.orderid FROM smj_evaluate e INNER JOIN smj_userinfo u ON e.uid = u.id INNER JOIN smj_order o ON e.order_id = o.id WHERE ( e.status=0 ) ORDER BY e.id LIMIT 0,5 "

2、如果是在model中打印sql

在model中打印,就不需要用M()实例化对象了,直接使用$this->getLastSql()即可。

3、select(false)方法打印sql

例如:

scss 复制代码
//在查询语句的select中加上false
 $arr = M('smj_evaluate')->alias('e')
      ->field('e.content,e.star,u.openid,o.orderid')
      ->join(' smj_userinfo  u ON e.uid = u.id')
      ->join(' smj_order o ON e.order_id = o.id')
      ->limit($p->firstRow,$p->listRows)
      ->order('e.id')
      ->where('e.status=0')
      ->select(false);
    var_dump($arr);

结果:

scss 复制代码
string(199) "SELECT e.content,e.star,u.openid,o.orderid FROM smj_evaluate e INNER JOIN smj_userinfo u ON e.uid = u.id INNER JOIN smj_order o ON e.order_id = o.id WHERE ( e.status=0 ) ORDER BY e.id LIMIT 0,5 "

打印sql还是很有必要掌握的一个技巧。有时候报错信息会很扯淡,这个时候每一个sql打印就让你瞬间知道到底是哪里出问题了。很赞。

多谢大牛同志的帮助。

end

相关推荐
我的golang之路果然有问题9 小时前
速成GO访问sql,个人笔记
经验分享·笔记·后端·sql·golang·go·database
M1A112 小时前
云原生第一步:Windows Go环境极速配置
后端·go
纪元A梦14 小时前
华为OD机试真题——推荐多样性(2025A卷:200分)Java/python/JavaScript/C++/C语言/GO六种最佳实现
java·javascript·c++·python·华为od·go·华为od机试题
K8sCat18 小时前
Golang与Kafka的五大核心设计模式
后端·kafka·go
孔令飞19 小时前
Go:终于有了处理未定义字段的实用方案
人工智能·云原生·go
唐僧洗头爱飘柔952720 小时前
(Go Gin)上手Go Gin 基于Go语言开发的Web框架,本文介绍了各种路由的配置信息;包含各场景下请求参数的基本传入接收
后端·golang·go·restful·gin·goweb开发
ん贤21 小时前
并发编程【深度解剖】
后端·go·并发
我的golang之路果然有问题1 天前
快速上手GO的net/http包,个人学习笔记
笔记·后端·学习·http·golang·go·net
用户16849371443111 天前
通过 goat 工具对 golang 应用进行增量代码的埋点和监控
go
旅人CS1 天前
用Go语言理解单例设计模式
设计模式·go