当前位置:首页 > CMS教程 > Thinkphp > 列表

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

发布:smiling 来源: PHP粉丝网  添加日期:2021-08-17 22:06:14 浏览: 评论:0 

这篇文章主要介绍了ThinkPHP5查询数据及处理结果的方法,结合实例总结分析了thinkPHP5常见查询语句及查询数据库的三种方式,需要的朋友可以参考下。

本文实例讲述了ThinkPHP5查询数据及处理结果的方法,分享给大家供大家参考,具体如下:

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

1. 查询某条记录

  1. $where=array
  2.   "version_id"=>$version_id 
  3. ); 
  4. $data = model("PackageWhitelist")->where($where)->find(); 
  5. $this->assign("package_id",$package_id); 
  6. $where=array
  7.   "package_id"=>$package_id 
  8. ); 
  9. $data = model("Package")->where($where)->find(); 
  10. if($data){ 
  11.   $this->assign("target_version",$data['target_version']); 

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

$device_number_list = model("PackageWhitelist")->where($where)->field("device_number")->find();

$this->assign("device_number",$device_number_list['device_number']);

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

  1. $where=array
  2.      "version_id"=>$version_id 
  3.  ); 
  4. $data = model("PackageWhitelist")->where($where)->field("device_number")->select(); 
  5. $device_number_list=''
  6. foreach($data as $val){ 
  7.   $list = $val->toArray(); 
  8.   if($device_number_list){ 
  9.     $device_number_list=$device_number_list.';'.$list["device_number"]; 
  10.   }else
  11.     $device_number_list=$list["device_number"]; 
  12.   } 

4. 查询多条记录

  1. $where=array
  2.   "version_id"=>$version_id 
  3. ); 
  4. $data = model("PackageWhitelist")->where($where)->select(); 
  5. $device_number_list=''
  6. foreach($data as $val){ 
  7.   $list = $val->toArray(); 
  8.   if($device_number_list){ 
  9.     $device_number_list=$device_number_list.';'.$list["device_number"]; 
  10.   }else
  11.     $device_number_list=$list["device_number"]; 
  12.   } 

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

  1. public function index($version_id){ 
  2.   $where=array
  3.     "version_id"=>$version_id 
  4.   ); 
  5.   $version_name = model("Version")->where($where)->field("version_name")->find(); 
  6.   $listrows=config("LISTROWS")?config("LISTROWS"):10; 
  7.   $package_lists=model("Package")->where($where)->paginate($listrows); 
  8.   $package_infos = $package_lists->toArray()["data"]; 
  9.   foreach($package_infos as $key=>$value){ 
  10.     $package_infos[$key] = array("source_version" => $version_name["version_name"]) + $package_infos[$key]; 
  11.   } 

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

方式一:原生sql查询

代码示例:

  1. <?php 
  2. /** 
  3.  * Created by PhpStorm. 
  4.  * User: chenzhitao 
  5.  * Date: 2017/5/8 
  6.  * Time: 下午2:15 
  7.  */ 
  8. namespace app\api\model; 
  9. use think\Db; 
  10. use think\Exception; 
  11. class Banner 
  12.   public static function getBannerByID($id){ 
  13.     $result = Db::query('select * from banner_item where banner_id=?',[$id]); 
  14.     return $result
  15.   } 

方式二:使用查询构建器

代码示例:

  1. <?php 
  2. /** 
  3.  * Created by PhpStorm. 
  4.  * User: chenzhitao 
  5.  * Date: 2017/5/8 
  6.  * Time: 下午2:15 
  7.  */ 
  8. namespace app\api\model; 
  9. use think\Db; 
  10. use think\Exception; 
  11. class Banner 
  12.   public static function getBannerByID($id){ 
  13.     //1.使用原生sql 
  14. //    $result = Db::query('select * from banner_item where banner_id=?',[$id]); 
  15. //    return $result; 
  16.     //2.使用查询构建器 
  17.     /* 
  18.      * 链式查询Db::table('banner_item')->where('banner_id','=',$id) 返回查询对象,->select();返回查询结果, 
  19.      * 除了select操作还有 find(返回一条数据) update delete insert 
  20.      * 对应的where 也分三种,1.表达式where('字段名','表达式','查询条件') 2.数组发 3.闭包。 
  21.      */ 
  22.     // 2.1 表达式法 
  23. //    $result = Db::table('banner_item') 
  24. //      ->where('banner_id','=',$id) 
  25. //      ->select(); 
  26. //    return $result; 
  27.     //2.2 闭包法 
  28.     $result = Db::table('banner_item'
  29.       ->where(function ($queryuse($id){ 
  30.         $query->where('banner_id','=',$id); 
  31.       }) 
  32.       ->select(); 
  33.     return $result
  34.   } 

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

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

代码示例:

model:

  1. <?php 
  2. /** 
  3.  * Created by PhpStorm. 
  4.  * User: chenzhitao 
  5.  * Date: 2017/5/8 
  6.  * Time: 下午2:15 
  7.  */ 
  8. namespace app\api\model; 
  9. use think\Db; 
  10. use think\Model; 
  11. class Banner extends Model 
  12. //  public static function getBannerByID($id){ 
  13. //    //1.使用原生sql 
  14. ////    $result = Db::query('select * from banner_item where banner_id=?',[$id]); 
  15. ////    return $result; 
  16. //    //2.使用查询构建器 
  17. //    /* 
  18. //     * 链式查询Db::table('banner_item')->where('banner_id','=',$id) 返回查询对象,->select();返回查询结果, 
  19. //     * 除了select操作还有 find(返回一条数据) update delete insert 
  20. //     * 对应的where 也分三种,1.表达式where('字段名','表达式','查询条件') 2.数组发 3.闭包。 
  21. //     */ 
  22. // 
  23. //    // 2.1 表达式法 
  24. ////    $result = Db::table('banner_item') 
  25. ////      ->where('banner_id','=',$id) 
  26. ////      ->select(); 
  27. ////    return $result; 
  28. //    //2.2 闭包法 
  29. //    $result = Db::table('banner_item') 
  30. //      ->where(function ($query) use($id){ 
  31. //        $query->where('banner_id','=',$id); 
  32. // 
  33. //      }) 
  34. //      ->select(); 
  35. //    return $result; 
  36. // 
  37. // 
  38. // 
  39. // 
  40. // 
  41. //  } 

controller:

  1. <?php 
  2. /** 
  3.  * Created by PhpStorm. 
  4.  * User: chenzhitao 
  5.  * Date: 2017/5/7 
  6.  * Time: 下午1:49 
  7.  */ 
  8. namespace app\api\controller\v1; 
  9. use app\api\validate\IDMustBePositiveInt; 
  10. use app\lib\exception\BannerMissException; 
  11. use app\api\model\Banner as BannerModel; 
  12. class Banner 
  13.   public function getBanner($id){ 
  14.      //调用验证器 
  15.     (new IDMustBePositiveInt())->goCheck(); 
  16. //    $banner = BannerModel::getBannerByID($id); 
  17.     $banner = BannerModel::get($id); 
  18.     if(!$banner){ 
  19.       throw new BannerMissException(); 
  20.     } 
  21.     return $banner
  22.   } 
  23. }

Tags: ThinkPHP5查询数据

分享到: