加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

ThinkPHP5查询数据及处理结果的方法小结

发布时间:2020-12-14 14:09:33 所属栏目:大数据 来源:网络整理
导读:本篇章节讲解ThinkPHP5查询数据及处理结果的方法。供大家参考研究具体如下: 在处理数据库查询结果时遇到了些问题,记录下用到过的几种查询方式和结果处理。 1. 查询某条记录 $version_id);$data = model("PackageWhitelist")->where($where)->fin

本篇章节讲解ThinkPHP5查询数据及处理结果的方法。分享给大家供大家参考,具体如下:

在处理数据库查询结果时遇到了些问题,记录下用到过的几种查询方式和结果处理。

1. 查询某条记录

$version_id ); $data = model("PackageWhitelist")->where($where)->find(); $this->assign("package_id",$package_id); $where=array( "package_id"=>$package_id ); $data = model("Package")->where($where)->find(); if($data){ $this->assign("target_version",$data['target_version']); }

2. 查询某条记录某个字段

where($where)->field("device_number")->find();
assign("device_number",$device_number_list['device_number']);

3. 查询多个记录某个字段 , 并处理结果,结果是一个数组集

$version_id ); $data = model("PackageWhitelist")->where($where)->field("device_number")->select(); $device_number_list=''; foreach($data as $val){ $list = $val->toArray(); if($device_number_list){ $device_number_list=$device_number_list.';'.$list["device_number"]; }else{ $device_number_list=$list["device_number"]; } }

4. 查询多条记录

$version_id ); $data = model("PackageWhitelist")->where($where)->select(); $device_number_list=''; foreach($data as $val){ $list = $val->toArray(); if($device_number_list){ $device_number_list=$device_number_list.';'.$list["device_number"]; }else{ $device_number_list=$list["device_number"]; } }

5. 以页形式查询,并处理结果。

$version_id ); $version_name = model("Version")->where($where)->field("version_name")->find(); $listrows=config("LISTROWS")?config("LISTROWS"):10; $package_lists=model("Package")->where($where)->paginate($listrows); $package_infos = $package_lists->toArray()["data"]; foreach($package_infos as $key=>$value){ $package_infos[$key] = array("source_version" => $version_name["version_name"]) + $package_infos[$key]; } }

再来总结一下TP5的三种查询数据库方式

方式一:原生sql查询

代码示例:

方式二:使用查询构建器

代码示例:

where('banner_id','=',$id) 返回查询对象,->select();返回查询结果,* 除了select操作还有 find(返回一条数据) update delete insert * 对应的where 也分三种,1.表达式where('字段名','表达式','查询条件') 2.数组发 3.闭包。 */ // 2.1 表达式法 // $result = Db::table('banner_item') // ->where('banner_id',$id) // ->select(); // return $result; //2.2 闭包法 $result = Db::table('banner_item') ->where(function ($query) use($id){ $query->where('banner_id',$id); }) ->select(); return $result; } }

方式三:ORM(Object Relation Mapping) 对象关系映射

使用ORM 查询数据库主要区别就是在写模型的继承thinkmodel类,然后控制器就可以使用model的默认方法来获取数据而不是自己再在模型中专门写一个获取方法

代码示例:

model:

where('banner_id',// * 除了select操作还有 find(返回一条数据) update delete insert // * 对应的where 也分三种,'查询条件') 2.数组发 3.闭包。 // */ // // // 2.1 表达式法 //// $result = Db::table('banner_item') //// ->where('banner_id',$id) //// ->select(); //// return $result; // //2.2 闭包法 // $result = Db::table('banner_item') // ->where(function ($query) use($id){ // $query->where('banner_id',$id); // // }) // ->select(); // return $result; // // // // // // } }

controller:

goCheck(); // $banner = BannerModel::getBannerByID($id); $banner = BannerModel::get($id); if(!$banner){ throw new BannerMissException(); } return $banner; } }

更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》、《》及《》。

希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读