fetchSql方法
1、功能:与select(false)基本一致,但支持更多的CURD操作;
2、源码:/thinkphp/library/think/db/Query.php/**
* 获取执行的SQL语句
* @access public
* @param boolean $fetch 是否返回sql
* @return $this
*/
public function fetchSql($fetch = true)
{
$this->options['fetch_sql'] = $fetch;
return $this;
}
3、参数与返回值:参数序号参数说明1true不执行查询,返回SQL语句
2false忽略该方法,继续执行后面操作返回值:当前查询对象Query
4、实例演示:
任务1:我们仍以上节课案例为讲,查询工资大于平均数的员工信息Index.php 控制器源码:<?php
namespace app\index\controller;
//导入数据库类
use think\Db;
class Index {
public function index(){
//1.生成子查询:计算平均工资
$subQuery = Db::table('tp5_staff') //设置数据表
-> field('avg(salary)') //字段列表可以使用聚合函数
-> fetchSql(true) //true:不执行查询,返回SQL语句 ,false:忽略,继续执行查询
-> select(); //此时select并不会执行
//2.执行父查询:获取大于平均工资的员工信息
$result = Db::table('tp5_staff') //设置数据表
-> field('id,name,salary') //设置查询字段列表
-> where('salary >= '.'('.$subQuery.')') //将子查询结果传给父查询
-> select(); //执行查询获取结果集
//3.查看结果
dump($result);
}
}这段代码仅是生成子查询部分与select(false)不同,其它地方完全一致。
查询结果也与上例完全一致,这里不再贴出。fetchSql还支持用在更新等其它语句中,下面是实例:
任务2:给tp5_staff表中优秀员工加薪500元,真是好老板呀~~由于不允许同表更新,所以从tp5_staff复制一张优秀员工表:tp5_good#创建tp5_good优秀员工表,数据来自tp5_staff表
CREATE TABLE tp5_good AS SELECT * FROM tp5_staff ;
# 在tp5_good表中添加一个字段good,用于存储是否是优秀员工标志,1:优秀,0:非
ALTER TABLE `tp5_good` ADD good INT unsigned NOT NULL ;
#将tp5_good表中,除good字段外的全部字段全部删除
ALTER TABLE tp5_good DROP name,DROP age,DROP sex,DROP dept, DROP hiredate,DROP salary;现在有了二张表:tp5_good 与tp5_staff
修改Index.php 控制器文件 :<?php
namespace app\index\controller;
//导入数据库类
use think\Db;
class Index {
public function index(){
//1.生成子查询:查询tp5_good表中good=1的员工id
$subQuery = Db::table('tp5_good') //设置数据表,不允许同表查询
-> field('id') //字段必须与父查询的条件字段一致
-> where('good','=',1) //设置子查询条件:good = 1 即优秀
-> fetchSql(true) //true:不执行查询,返回SQL语句 ,false:忽略,继续执行查询
-> select(); //此时select并不会执行
//2.执行父查询:给优秀员工加薪500
$affected = Db::table('tp5_staff') //设置数据表
-> where('id in '.'('.$subQuery.')') //将子查询结果传给父查询字段IN条件
-> update(['salary'=>['exp','salary + 500']]); //更新成功则返回影响记录数量
//3.查看结果
dump($affected); // int(6) : 有6条记录被更新
}
}运行结果:int(6) // 6条记录被更新,执行成功生成的更新SQL语句:UPDATE `tp5_staff` SET `salary`=salary + 500
WHERE ( id in (SELECT `id` FROM `tp5_good` WHERE `good` = 1 ) )
5、总结:fetchSql 和 select(false) 参数都是布尔值,返回都是SQL语句,但是在拼接查询条件时,还是有一些麻烦,下节课要学到的buildSql方法更适合生成子查询语句。