tp5.1 php 对象转数组(items paginate)

264 篇文章 5 订阅

一、实例:

代码

$list =  Db::name('order')
				->field('id,number,price,type,state,time,pay_time,pay_number,time,express_state,express_id,mold')
				->where($where)
				->order(['id' => 'desc'])
				->paginate($limit,false,['query' => request()->param(),'type' => 'page\Page','var_page'  => 'page']);

输出是对象

dump($list);

要取得数组

写法:

dump($list->items());exit;

 

 

二、其它对象输出方法:

object(WxPayUnifiedOrder)#49 (1) {
  ["values":protected] => array(6) {
    ["body"] => string(19) "菜鸟晋升课程|"
    ["out_trade_no"] => string(17) "20191117010631610"
    ["total_fee"] => float(100)
    ["notify_url"] => string(28) "http://www.cg.com/notify.php"
    ["trade_type"] => string(6) "NATIVE"
    ["product_id"] => int(1573923991)
  }
}

转为数组方法一:

/**
 * @desc 对象转化为数组
 * @param $array  object_data
 * @return array  
 */
function object_array($array)
{
   if(is_object($array))
   {
    $array = (array)$array;
   }
   if(is_array($array))
   {
    foreach($array as $key=>$value)
    {
     $array[$key] = object_array($value);
    }
   }
   return $array;
}

转为数组方法二:

$arrr=(array)$inputObj);
dump($arrr);

两种方式输出:

array(1) {
  ["*values"] => array(6) {
    ["body"] => string(19) "菜鸟晋升课程|"
    ["out_trade_no"] => string(17) "20191117011128528"
    ["total_fee"] => float(100)
    ["notify_url"] => string(28) "http://www.cg.com/notify.php"
    ["trade_type"] => string(6) "NATIVE"
    ["product_id"] => int(1573924288)
  }
}

注意: ["*values"] => array(6) {          ["*values"]键值是错误的

需要数组将使用数值键,从 0 开始并以 1 递增。

array_values() 函数

 

正确方法是:

		$arrr=array_values(object_array($inputObj));
		$arrr=array_values((array)$inputObj);

输出:

array(1) {
  [0] => array(6) {
    ["body"] => string(19) "菜鸟晋升课程|"
    ["out_trade_no"] => string(17) "20191117013844171"
    ["total_fee"] => float(100)
    ["notify_url"] => string(28) "http://www.cg.com/notify.php"
    ["trade_type"] => string(6) "NATIVE"
    ["product_id"] => int(1573925924)
  }
}

取值:

          dump($arrr);
          dump($arrr[0]);
          dump($arrr[0]['out_trade_no']);die;

 

 

tp5.1中的order FIELD可以通过使用orderRaw函数来实现。在orderRaw函数中,可以传入带有FIELD函数的排序字段,并且可以使用asc或desc来指定排序的方式。例如,可以这样写代码来实现按照u_id=0排序,然后按照sort排序的功能: ``` $or_str = "FIELD(u_id,0) desc,sort asc"; $p = db('product')->field('id,u_id,name,cover_img,sort,count') ->where('product_id', $ppi) ->orderRaw($or_str) ->paginate($limit)->jsonSerialize(); ``` 注意,order函数已经不再适用,应该使用orderRaw函数来构建排序语句。orderRaw函数可以解析mysql函数FIELD,并且可以通过传入bind参数来绑定参数。如果需要查看构建的SQL语句而不进行查询,可以使用fetchSql方法,并将其设置为true。例如: ``` $subQuery = Db::table('think_user') ->field('id,name') ->where('id', '>', 10) ->fetchSql(true) ->select(); ``` 这样可以得到构建的SQL语句而不进行实际的查询操作。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [TP5,TP6数据排序方法按指定函数FIELD排序的方法](https://blog.csdn.net/weixin_42433970/article/details/122556042)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [tp5.1--数据库子查询](https://blog.csdn.net/qq_42176520/article/details/88695871)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值