thinkphp6打印输出sql语句的3种方法

知识技术 2022-03-10 22:43 4261
转载请务必注明: 来源:《建站管家》https://www.df81.com/news/258.html

方法一:在链式写法的语句后面执行以下语句:

本例前缀:

$Db = Db::name($tableName);
$Db->field($field);
$Db->where($where)->select();

调用此句:

echo  $Db->getLastSql();exit;


方法二:在链式写法的中间添加fetchSql:

本例前缀:

$Db = Db::name($tableName);
$Db->field($field);

调用此句:

echo   $returnRes = $Db->fetchSql()->select();


注意:以上语句需要echo 并且fetchSql必须在select之前。原因是select直接返回了一个数据集。而其他链式写法返回this。


方法三:自己在common.php中写一个方法

function sql(){
    echo db()->getLastSql();
    exit;
}

如果是模型,还可以用 getLastSql(), 获取方法前最后一条 SQL 原生语句,代码:

XXX::where('id', 1)->find();
dd(XXX::getLastSql());

执行结果

SELECT * FROM `xxx` WHERE  `id` = 1 LIMIT 1

点赞 (0)

收藏 (0)

本站部分信息来源网络,如有侵权,请联系QQ:1062129401删除。

上一篇: 《建站管家》二次开发文档

下一篇: jQuery操作动态添加元素的方法,超easy!

请先登录后,再发表评论 ~ ~
发表评论
发表评论
发表帖子
广告位招租( ¥5 / 天 )
点击咨询
相关帖子

如果要判断文件是否存在,用函数 is_file(),如果要判断目录是否存在,用函数 is_dir()
用宝塔安装TP程序后,网站前台可以访问,后台无法访问,不是程序问题,而是web服务器环境配置问题(PHP配置),出现这种问题,一般是windows主机安装宝塔造成的,linux安装宝塔不会出现此错误
广告位招租( ¥3 / 天 )
点击咨询
广告位招租( ¥2 / 天 )
点击咨询
广告位招租( ¥1 / 天 )
点击咨询
最新帖子

小朋友,你爸爸是谁啊?这很单纯的,就像我们碰到别人会问:你吃过饭了吗?类似;许多人初次相识,经常会问:你是做什么的啊?你做什么,好像决定你收入的高低,你,资产的范围
1、升级框架到ThinkPHP8.0.3【要求PHP8.1+环境,推荐PHP8.1】 2、启用/禁用调试模式等小细节改进
后台点击生成站点地图 一直转圈圈没有反应,
在线客服