ThinkPHP5数据库实例详解
/fetchSql方法
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方法更适合生成子查询语句。