fetchSql方法

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、参数与返回值:

  • 参数
序号 参数 说明
1 true 不执行查询,返回SQL语句
2 false 忽略该方法,继续执行后面操作
  • 返回值:当前查询对象Query

4、实例演示:

任务1:我们仍以上节课案例为讲,查询工资大于平均数的员工信息
  • Index.php 控制器源码:
 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 控制器文件 :

 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方法更适合生成子查询语句。